hibernate批量操作

hibernate批量操作

有以下四种方式来进行批量操作

  • 通过session

  • 通过HQL

  • 通过statelessSession

  • 通过JDBCAPI 使用该方式效率最高,速度最快

通过session

通过session批量操作时:session的save()及update()方法会把处理的对象存放在自己的缓存中,如果使用session来处理大量持久化对象,需要及时从缓存中清空已经处理完毕且不会再访问的对象(处理完一批对象后,立即调用flush()方法刷新缓存,然后调用clear()方法清空缓存)

注意

  • 在hibernate配置文件中设置JDBC单次批量的数目,应保证每次想数据库发送的批量SQL语句数目与batch_size属性一致

  • 如果主键由数据库自增生成的话,无法使用批量操作

通过HQL

不能进行批量插入,更新只能操作一条sql语句(比如说将某个值批量改为某个数)

通过StatelessSession

  • StatelessSession没有缓存,使用该类来加载、保存、更新后的对象处于游离状态
  • 调用save()、update()、delete()方法时会立即执行SQL语句
  • StatelessSession不会对所加载的对象自动进行脏检查。需要进行显示的save()/update()
  • StatelessSession不会对关联的对象进行任何级联操作
  • 通过同一个StatelessSession加载相同OID的对象,会得到两个具有不同内存地址的对象
  • StatelessSession可以被Interceptor拦截器拦截到,但是会被hibernate事件处理系统忽略

通过JDBCAPI

java 复制代码
session.doWork(new Work() {
  @Override
  public void execute(Connection connection) throws SQLException {

  }
});

zhhll.icu/2020/框架/hib...

本文由mdnice多平台发布

相关推荐
lee_curry2 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
九转成圣3 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
直奔標竿4 小时前
Java开发者AI转型第二十七课!Spring AI 个人知识库实战(六)——全栈闭环收官,解锁前端流式渲染终极技巧
java·开发语言·前端·人工智能·后端·spring
金銀銅鐵4 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
野生技术架构师6 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
小袁拒绝摆烂6 小时前
多表关联大平层转JSON树形结构
java·json
ja哇7 小时前
大厂面试高频八股
java·面试·职场和发展
yoyo_zzm7 小时前
Laravel6.x新特性全解析
java·spring boot·后端
Nick_zcy8 小时前
小说在线阅读网站和小说管理系统 · 功能全解析
java·后端·python·springboot·ruoyi