SpringBoot JpaRepository 数据库增删改查

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

版本:spring data 2.0.7

包结构:

SpringBoot JpaRepository 数据库增删改查_第1张图片

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

SpringBoot JpaRepository 数据库增删改查_第2张图片

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 save(Device obj);
	void delete(Device obj);
    Optional findById(Long id);
	List findAll();
	List 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 getOne(@PathVariable("id") Long id){
		Optional obj2 = repo.findById(id);
		return obj2;
	}
	
	/**查出全部 */
	@RequestMapping("/all")
	public List findAll(){
		List persons = repo.findAll();
		return persons;
	}
	
	/**根据编号查找 */
	@RequestMapping("/no/{no}")
	public List findByNo(@PathVariable("no") String no){
		List persons = repo.findByNo(no);
		return persons;
	}
	 
}

 

你可能感兴趣的:(web开发,数据库)