目录
springboot+spring data jpa实现新增及批量新增
spring data jpa (以下简称jpa)。这个orm其实和mybatis还是差不多的。但是相对于mybatis来说,省去很多方法,毕竟jpa来说,官方文档给的说法是编写者只需要书写接口。剩下的事就交由jpa来完成。当时,洒家还是不信的。当你用过一次后,你就会发现。真的是这样。只能用两个字来形容,即是“真香”。
好了,废话不多说了。今天贴的代码不包含基础配置哈。。
实体类如下:
controller层:
@PostMapping(value = \"/add\") @ApiOperation(value = \"新增功能\", notes = \"新增功能\") public ResultVo<?> addInfo(@RequestBody @Valid SysAdminUser adminUser){ return demoService.addInfo(adminUser); }
service层:
public ResultVo<?> addInfo(SysAdminUser adminUser){ SysAdminUser sysAdminUser = modelMapper.map(adminUser, SysAdminUser.class); demoRepository.save(sysAdminUser); return ResultVo.success(); }
repository层:
其实,具体的单条数据添加还是看个人的业务逻辑而说,每个人想法不一样,写的代码方式也不一样。如您有更好的写法。也可以贴出来,大家一起进步。
说完单条,该说批量了
用的实体类都是一样的
controller层:
@PostMapping(value = \"/batch/add\") @ApiOperation(value = \"新增功能\", notes = \"批量新增\") public Map<String,Object> addListModelParams(@RequestBody List<SysAdminUser> list) { int listsize = list.size(); Map<String,Object> resultMap = new HashMap<>(); if (listsize == 0) { throw new RuntimeException(\"集合为空!\") ; } else { //批量存储的集合 List<SysAdminUser> data = new ArrayList<SysAdminUser>(); //批量存储 for (SysAdminUser s : list) { if(data.size() == listsize/10) { demoService.save(data); data.clear(); } data.add(s); } //将剩下的数据也导入 if(!data.isEmpty()) { demoService.save(data); resultMap.put(\"code\", \"0000\"); resultMap.put(\"message\", \"批量添加成功\"); } } return resultMap; }
service层:
public void save(List<SysAdminUser> list) { demoRepository.saveAll(list); }
因为在service层的时候,它其实也调的是jpa里面自带的方法。
而repository层的代码也是单纯的一个接口罢了
如下:
springdatajpa 新增操作注意
org.hibernate.PersistentObjectException: detached entity passed to persist异常
简单地来看,将一个游离的对象要被持久化(save)时报错。
我们知道要持久化对象时候,通常Hibernate会根据ID生成策略自动生成ID值,但是这个对象ID已经有值,所有抛错。
这个错误是我在配置如下1一对多@OneToMany的关联关系时报的错。
@OneToMany(targetEntity = Role.class, cascade = CascadeType.ALL, fetch = FetchType.EAGER) @JoinTable(name = \"sys_user_role\", joinColumns = @JoinColumn(name = \"user_id\", referencedColumnName = \"id\"), inverseJoinColumns = @JoinColumn(name = \"role_id\", referencedColumnName = \"id\", unique = true)) private Set<Role> roles = new HashSet<>();
因为级联关系是CascadeType.ALL,所以save时会保存级联的对象Role,但是Role已经存在,因此就报错了。
将cascade改为CascadeType.MERGE或者CascadeType.REFRESH即可,表示级联对象在Role表存在则进行update操作,而不做save操作。级联操作时谨慎用CascadeType.ALL
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
做猪小侠源码的代理,提供一站式服务
如果你不懂得搭建网站或者服务器,小程序,源码之类的怎么办? 第一通过本站学习各种互联网的技术 第二就是联系客服,我帮帮你搭建(当然要收取部分的费用) 第三成为我们的代理,我们提供整套的服务。