当前位置:首页 > 开发 > 编程语言 > Hibernate > 正文

Hibernate 脏数据(session.isDirty())

发表于: 2011-06-10   作者:crabdave   来源:转载   浏览次数:
摘要: Hibernate 脏数据(session.isDirty())         持久对象总是与Session和Transaction相关联,在一个Session中,对持久对象的改变不会马上对数据库进行变更,而必须在Transaction终止,也就是执行commit()之后,才在数据库中真正运行SQL进行变更,持久对象的状态才会与数据

Hibernate 脏数据(session.isDirty())

 

      持久对象总是与Session和Transaction相关联,在一个Session中,对持久对象的改变不会马上对数据库进行变更,而必须在Transaction终止,也就是执行commit()之后,才在数据库中真正运行SQL进行变更,持久对象的状态才会与数据库进行同步。在同步之前的持久对象称为脏(dirty)对象。

 

java代码片断如下:

	public void sessionDirtyTest(){
		User user=new User();
		user.setUserid(new BigDecimal(1));               
		user.setLoginName("crabdave");        
		user.setUsername("David");         
		user.setPassword("David");         
		user.setSex("male");               
		user.setFixPhone("123456");        
		user.setMobilePhone("1234567890"); 
		user.setDeleteFlag("1");           
		user.setStatus("1");               
		user.setAge("27");                 
		user.setContract("1");             
		user.setDepartment("dept");        

		ApplicationContext ac = new FileSystemXmlApplicationContext("D:/PracticeWorkSpace/SSHPractice/src/main/resources/struts_1_spring.xml"); 
		SessionFactory sessionFactory = ((HibernateTemplate)ac.getBean("hibernateTemplate")).getSessionFactory();
		Session session=sessionFactory.openSession();
		System.out.println("1.session.isDirty():"+session.isDirty());
		Transaction tx=session.beginTransaction();
		System.out.println("2.session.isDirty():"+session.isDirty());
		tx.begin();
		System.out.println("3.session.isDirty():"+session.isDirty());
		session.update(user);
		System.out.println("4.session.isDirty():"+session.isDirty());
		tx.commit();
		System.out.println("5.session.isDirty():"+session.isDirty());
		session.close();
		System.out.println("6.session.isDirty():"+session.isDirty());
	}

 

运行结果如下:

1.session.isDirty():false
2.session.isDirty():false
3.session.isDirty():false
4.session.isDirty():true
Hibernate: update user set loginName=?, username=?, password=?, sex=?, fixPhone=?, mobilePhone=?, deleteFlag=?, status=?, age=?, contract=?, department=? where userid=?
5.session.isDirty():false
Exception in thread "main" org.hibernate.SessionException: Session is closed!

Hibernate 脏数据(session.isDirty())

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
脏检查 Session到底是如何进行脏检查的呢?当一个Customer对象被加入到Session缓存中时,Session会
《高性能MySQL》里有这么一段: 那么,假设有如下场景,查询C应当会读到什么结果? A出对数据的更新
译者 whatevery 像苹果一样可以提供云计算服务的企业已经在数字时代被赋予了权力。但是,我们对数据
SQL Server死锁总结 1. 死锁原理 根据操作系统中的定义:死锁是指在一组进程中的各个进程均占有不会
常见并发并发一致性问题包括:丢失的修改、不可重复读、读脏数据、幻影读(幻影读在一些资料中往往
地址: http://hi.baidu.com/zhuxixi527/blog/item/eba16af89f19b50ad8f9fd25.html 终极优化你的游戏
批量处理数据是指在一个事务中处理大量数据. 在应用层进行批量操作, 主要有以下方式: 通过 Session
8月免费课 8月DIY课程 咱们家里的擦脸或擦手毛巾用的时间久了,特别是经常湿漉漉的就挂在卫生间里阴
'SQLServer:Buffer Manager\Page writes/sec' :Number of physical database page writes issued pe
'SQLServer:Buffer Manager\Page writes/sec' :Number of physical database page writes issued pe
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号