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多平台发布

相关推荐
马尚道8 分钟前
Java高手速成--吃透源码+手写组件+定制开发教程
java
我命由我1234513 分钟前
Spring Cloud - Spring Cloud 注册中心与服务提供者(Spring Cloud Eureka 概述、微服务快速入门、微服务应用实例)
java·spring boot·spring·spring cloud·微服务·eureka·java-ee
MetaverseMan17 分钟前
Java Spring 框架的`@Autowired` 注解 以及依赖注入分析
java·开发语言·spring
一吃就胖的23 分钟前
【给服务器安装服务器安装nacos】
java·运维·服务器
码住懒羊羊35 分钟前
【C++】stack|queue|deque
java·开发语言·c++
hdsoft_huge37 分钟前
第六章 Kettle(PDI)解锁脚本组件:数据处理的可编程利器
java·大数据·etl
聪明的笨猪猪1 小时前
Java JVM “内存(1)”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
程序员清风1 小时前
快手二面:乐观锁是怎么用它来处理多线程问题的?
java·后端·面试
一线大码1 小时前
SpringBoot 优雅实现接口的多实现类方式
java·spring boot·后端
花伤情犹在2 小时前
Java Stream 高级应用:优雅地扁平化(FlatMap)递归树形结构数据
java·stream·function·flatmap