Hibernate的锁机制

Hibernate的锁机制:

悲观锁,有一个用户读取时,其他用户就不能读取。只有当用户释放锁时,其他用户才能读取。

利用hibernate配置文件生成数据库:

//读取hibernate.cfg.xml文件

        Configuration cfg = new Configuration().configure();

        

        SchemaExport export = new SchemaExport(cfg);

        

        export.create(true, true);

 

hibernate锁:

Inventory inv = (Inventory)session.load(Inventory.class, 1, LockMode.UPGRADE);

 

缺点并发性不好

 

乐观锁:使用冲突检测的方法,旧数据不允许修改新的数据

并发性较好

大多数基于数据版本记录机制(version)实现,一般是在数据库表中加入一个version字段

读取数据时将版本号一同读出,之后更新数据时版本号加一,如果提交数据时版本号小于或等于数据表中的版本号,则认为数据是过期的,否则给予更新

 

对实体要进行配置,并添加属性:

    optimistic-lock="version">

        

            

        

        <version name="version"/>

        

        

    

 

 

一级缓存是缓存实体对象的,普通属性不会缓存。

一级缓存和session的生命周期是一致的。

Save使用缓存。

Session.clear();管理一级缓存方法。

批量加入数据要定时清理缓存。

    Session.flush();//强制将数据持久化

Session.clear();

 

二级缓存也只缓存实体对象,sessionFactory级缓存,可以被所有session共享。

EhCache

使用etc目录下的ehcache.xml文件。

 

在hibernate中开启二级缓存

org.hibernate.cache.EhCacheProvider

 

Read only

在hibernate配置文件中

你可能感兴趣的:(hibernate,session,数据库)