博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HIbernate数据动态更新
阅读量:6864 次
发布时间:2019-06-26

本文共 1332 字,大约阅读时间需要 4 分钟。

hot3.png

当spring整合hibernate之后事务就会被spring进行托管,那么当你在一个get一个对象之后在进行set对象时候你发现,事务提交后会执行一段update语句,数据库中的值也会改变,这就是动态更新。就是说,你的查询和赋值同时在一个相同的session中进行的,hibernate根据id判断是同一个对象,所以会自动更新相应的属性值。 

其实自动更新只是为了提高效率。 如果你不想让它自动更新,你们可采取以下方法: 在映射文件相应属性中设置update="false"可以不用更新该字段或者是在映射文件中的class标签里面加上:dynamic-insert="false" 

就像下边这样: 

<class name="com.orm.UserInfo"     table="user_info"     

         dynamic-update="false"     

         dynamic-insert="true"    

         optimistic-lock="version">

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");session = HibernateUtil.openSession();session.beginTransaction();User u = new User();u.setBorn(new Date());u.setUsername("zhangsan");u.setPassword("zhangsan");session.save(u);u.setPassword("222");           //该条语句没有意义            session.save(u);u.setPassword("zhangsan111");           //没有意义            session.update(u);u.setBorn(sdf.parse("1988-12-22"));            //没有意义            session.update(u);session.getTransaction().commit();

这个时候会发出多少sql语句呢?还是同样的道理,在调用save方法后,u此时已经是持久化对象了,记住一点:如果一个对象以及是持久化状态了,那么此时对该对象进行各种修改,或者调用多次update、save方法时,hibernate都不会发送sql语句,只有当事物提交的时候,此时hibernate才会拿当前这个对象与之前保存在session中的持久化对象进行比较,如果不相同就发送一条update的sql语句,否则就不会发送update语句

Hibernate: insert into t_user (born, password, username) values (?, ?, ?)Hibernate: update t_user set born=?, password=?, username=? where id=?

这样

转载于:https://my.oschina.net/u/2255569/blog/340644

你可能感兴趣的文章