hibernate小知识点总结--持续更新

来源:互联网 发布:solidworks软件百度云 编辑:程序博客网 时间:2024/06/05 02:11

1. hibernate中只更新部分字段

hibernate中如果直接使用update 或者 saveOrUpdate方法,会把表中所有的字段更新一遍。

但是修改时,form表单只提交需要更新的字段.

解决方法:

在不需要更新的字段(如创建时间,id)上,加上updae="false"

示例:

注解方式

@Column(name="created_time",updatable=false)public Date getCreateTime() {return createTime;}
或者

xml配置:

<property name="createtTime" column="created_time" update="false"></property>  

2. hibernate的悲观锁和乐观锁 

hibernate的乐观锁:在表中增加一个version字段,当提交数据时,从表中获取version的值,跟现在的versioon进行对比.如果现有的versioon小于表中的version,则说明有人提前进行了提交,则取消此次操作。否则,正常操作。

hibernate的悲观锁:通过数据库的机制来进行加锁

示例:select * from account where name = "12345" for update,通过for update子句,这条SQL锁定了account表中所有符合检索条件的记录。本次事务提交之前(事务提交时会释放事务过程中的锁),外界无法修改这些记录。

Hibernate 的悲观锁,也是基于数据库的锁机制实现。

下面的代码实现了对查询记录的加锁:

String hqlStr = "from TUser as user where user.name='123456'";

Query query = session.createQuery(hqlStr);

query.setLockMode("user",LockMode.UPDATE);//加锁

List userList = query.list();

 

3. load与get的区别

http://www.cnblogs.com/xiaoluo501395377/p/3371776.html


--未完待续----

原创粉丝点击