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;
	}
	 
}

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鹰信息技术服务部

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值