SpringBoot JpaRepository 数据库增删改查

今天周末,自主学习,本周探索了一下SpringBoot 的数据库操作,相比于四年前接触的hibernate,SpringBoot的数据库操作在便利性上有非常大的提升,代码量也小了很多,值得一试。案例代码记录如下(注意部分方法与spring data的早期版本有区别):

版本:spring data 2.0.7

包结构:

数据库部分:项目启动时根据实体类自动建表,不需要手动建表,非常智能。

1. 实体类:Device.java

@Entity
public class Device {
	@Id
	@GeneratedValue(strategy = GenerationType.IDENTITY) 
	private Long id;
	private String no;
	private String name;
	//...
}

2. Repo: DeviceRepo.java

public interface DeviceRepo extends JpaRepository<Device, Long> {
	Device save(Device obj);
	void delete(Device obj);
    Optional<Device> findById(Long id);
	List<Device> findAll();
	List<Device> findByNo(String no);
}

3. Ctrl: DeviceCtrl

@RestController
@RequestMapping("/webapp/device")
public class DevictCtrl {
	
	@Autowired
	DeviceRepo repo;
	
	/**保存(无id)/更新(有id) */
	@POST
	@RequestMapping("/")
	public Device save(@RequestBody Device obj){
		Device obj2 = repo.save(obj);
		return obj2;
	}
	
	/**删除 */
	@DELETE
	@RequestMapping("/delete")
	public void delete(@RequestBody Device obj){
		repo.delete(obj);
	}
	
	/**根据id查找 */
	@RequestMapping("/{id}")
	public Optional<Device> getOne(@PathVariable("id") Long id){
		Optional<Device> obj2 = repo.findById(id);
		return obj2;
	}
	
	/**查出全部 */
	@RequestMapping("/all")
	public List<Device> findAll(){
		List<Device> persons = repo.findAll();
		return persons;
	}
	
	/**根据编号查找 */
	@RequestMapping("/no/{no}")
	public List<Device> findByNo(@PathVariable("no") String no){
		List<Device> persons = repo.findByNo(no);
		return persons;
	}
	 
}

猜你喜欢

转载自blog.csdn.net/zhouyingge1104/article/details/84483033