传智播客 Hibernate 对象状态与存储性能优化

 

    使用Hibernate将对象持久化到数据库中时,最重要的是区分持久化对象的状态。一个持久化对象有三种状态,分别是瞬态,持久化、和托管。所谓瞬态(Transient),就是由new操作符创建,且尚未与Hibernate Session 关联的对象被认定为瞬态。瞬态对象没有被持久化到数据库中,也没有被赋予持久化标识(identifier)。 如果程序中没有保持对瞬态对象的引用,它会被垃圾回收器销毁。 使用Hibernate Session可以将其变为持久化(Persistent)状态(Hibernate会自动执行必要的SQL语句)。而持久化(Persistent)是指持久化实例在数据库中有对应的记录,并拥有一个持久化标识(identifier)。 持久(Persistent)的实例可能是刚被保存的,或刚被加载的,无论哪一种,持久化对象都必须与指定的Hibernate session关联。 Hibernate会检测到处于持久化状态的对象的任何改动,在当前操作单元执行完毕时将对象数据与数据库同步,开发者不需要手动执行UPDATE。最后就是托管(Detached)状态,它是指与持久化对象关联的Session被关闭后,对象就变为托管状态(Detached)。 对托管对象的引用依然有效,对象可继续被修改。托管对象如果重新关联到某个新的Session上, 会再次转变为持久化状态(托管对象其间的改动将被持久化到数据库中)。
    理解上面的概念是更好的操作Hibernate的关键。下面来了解对于用户来说,Hibernate最核心的东西——配置文件和映射文件,总的来说,都只配置文件。hibernate.cfg.xml的常用属性如下:
      connection.url:数据库URL
      connection.username:数据库用户名
      connection.password:数据库用户密码
      connection.driver_class:数据库JDBC驱动
      show_sql:是否将运行期生成的SQL输出到日志以供调试。取值 true | false
      dialect:配置数据库的方言,根据底层的数据库不同产生不同的sql语句,Hibernate 会针对数据库的特性在访问时进行优化。
      hbm2ddl.auto:在启动和停止时自动地创建,更新或删除数据库模式。取值 create | update | create-drop
      mapping resource:映射文件配置,配置文件名必须包含其相对于根的全路径
      connection.datasource :JNDI数据源的名称
    还有两个属性是在部署应用的时候需要知道的,jdbc.fetch_size 和 jdbc.batch_size,它们对性能有一定的影响。首先是关于jdbc.fetch_size:实质是调用 Statement.setFetchSize() 方法设定JDBC的Statement读取数据的时候每次从数据库中取出的记录条数。例如一次查询1万条记录,对于Oracle的JDBC驱动来说,是不会 1 次性把1万条取出来的,而只会取出Fetch Size条数,当纪录集遍历完了这些记录以后,再去数据库取Fetch Size条数据。因此大大节省了无谓的内存消耗。当然Fetch Size设的越大,读数据库的次数越少,速度越快;Fetch Size越小,读数据库的次数越多,速度越慢。Oracle数据库的JDBC驱动默认的Fetch Size=10,是一个保守的设定,根据测试,当Fetch Size=50的时候,性能会提升1倍之多,当Fetch Size=100,性能还能继续提升20%,Fetch Size继续增大,性能提升的就不显著了。建议使用Oracle时将Fetch Size设到50。并不是所有的数据库都支持Fetch Size特性,例如MySQL就不支持。MySQL就像上面那种最坏的情况,总是一下就把1万条记录完全取出来,内存消耗会非常非常惊人!这个情况就没有什么好办法了。
    第二个就是jdbc.batch_size:设定对数据库进行批量删除,批量更新和批量插入的时候的批次大小,有点相当于设置Buffer缓冲区大小的意思。Batch Size越大,批量操作的向数据库发送sql的次数越少,速度就越快。测试结果是当Batch Size=0的时候,使用Hibernate对Oracle数据库删除1万条记录需要25秒,Batch Size = 50的时候,删除仅仅需要5秒!可见有多么大的性能提升!Oracle数据库 Batch Size = 30 的时候比较合适。这两个选项非常重要,将严重影响Hibernate的CRU(create,read,update,delete)性能!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值