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

 更新时间:2021年11月23日 10:09:00   作者:不缺从头再来的勇气  
这篇文章主要介绍了springboot+spring data jpa实现新增及批量新增方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

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

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

相关文章

  • Eclipse将Maven项目打成jar包的方法

    Eclipse将Maven项目打成jar包的方法

    这篇文章主要介绍了Eclipse将Maven项目打成jar包的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2007-09-09
  • 教你如何把Eclipse创建的Web项目(非Maven)导入Idea

    教你如何把Eclipse创建的Web项目(非Maven)导入Idea

    这篇文章主要介绍了教你如何把Eclipse创建的Web项目(非Maven)导入Idea,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • 有关ThreadLocal的面试题你真的懂了吗

    有关ThreadLocal的面试题你真的懂了吗

    这篇文章主要介绍了面试题ThreadLocal,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-06-06
  • 详解Java8新特性如何防止空指针异常

    详解Java8新特性如何防止空指针异常

    要说 Java 编程中哪个异常是你印象最深刻的,那 NullPointerException 空指针可以说是臭名昭著的,不要说初级程序员会碰到, 即使是中级,专家级程序员稍不留神,就会掉入这个坑里,本文就和大家聊聊Java8新特性如何防止空指针异常
    2023-08-08
  • zookeeper集群搭建超详细过程

    zookeeper集群搭建超详细过程

    这篇文章主要介绍了zookeeper集群搭建超详细过程,本文对zookeeper集群测试通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • 一篇文章带你了解Java SpringBoot四大核心组件

    一篇文章带你了解Java SpringBoot四大核心组件

    这篇文章主要介绍了SpringBoot四大核心组件的使用小结,详细的介绍了这方面的知识,有兴趣的可以了解一下,希望能够给你带来帮助
    2021-09-09
  • MyBatis-Plus 动态表名SQL解析器的实现

    MyBatis-Plus 动态表名SQL解析器的实现

    这篇文章主要介绍了MyBatis-Plus 动态表名SQL解析器的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • 详解Java中native方法的使用

    详解Java中native方法的使用

    native是与C++联合开发的时候用的!使用native关键字说明这个方法是原生函数,也就是这个方法是用C/C++语言实现的,并且被编译成了DLL,由java去调用。本文给大家介绍java 中native方法使用,感兴趣的朋友一起看看吧
    2020-09-09
  • Spring自动装配@Autowired教程

    Spring自动装配@Autowired教程

    @Autowired注解是Spring中非常重要且常见的,接下来就简要的介绍一下它的用法。@Autowired默认是通过set方法,按照类型自动装配JavaBean,set方法可省略不写,它主要是修饰在成员变量上
    2023-01-01
  • 基于Java实现一个简单的单词本Android App的实践

    基于Java实现一个简单的单词本Android App的实践

    本文基于Java实现了一个简单的单词本安卓app,用的是SQLite数据库,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01

最新评论