今天周末,自主学习,本周探索了一下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;
}
}