欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

springboot+spring data jpa实现新增及批量新增方式

程序员文章站 2022-03-20 14:21:39
目录springboot+spring data jpa实现新增及批量新增springdatajpa 新增操作注意springboot+spring data jpa实现新增及批量新增spring d...

springboot+spring data jpa实现新增及批量新增

spring data jpa (以下简称jpa)。这个orm其实和mybatis还是差不多的。但是相对于mybatis来说,省去很多方法,毕竟jpa来说,官方文档给的说法是编写者只需要书写接口。剩下的事就交由jpa来完成。当时,洒家还是不信的。当你用过一次后,你就会发现。真的是这样。只能用两个字来形容,即是“真香”。

好了,废话不多说了。今天贴的代码不包含基础配置哈。。

实体类如下:

springboot+spring data jpa实现新增及批量新增方式

controller层:

@postmapping(value = "/add")
    @apioperation(value = "新增功能", notes = "新增功能")
    public resultvo<?> addinfo(@requestbody @valid sysadminuser adminuser){
        return  demoservice.addinfo(adminuser);
    }

springboot+spring data jpa实现新增及批量新增方式

service层:

public  resultvo<?> addinfo(sysadminuser adminuser){
        sysadminuser sysadminuser = modelmapper.map(adminuser, sysadminuser.class);
        demorepository.save(sysadminuser);
        return resultvo.success();
    }

repository层:

springboot+spring data jpa实现新增及批量新增方式

其实,具体的单条数据添加还是看个人的业务逻辑而说,每个人想法不一样,写的代码方式也不一样。如您有更好的写法。也可以贴出来,大家一起进步。

说完单条,该说批量了

用的实体类都是一样的

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层的代码也是单纯的一个接口罢了

如下:

springboot+spring data jpa实现新增及批量新增方式

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。