Hibernate-学习笔记04-数据更新方法

 

试验目的:

更新数据库中某一字段,其余字段不变。

 

(1)使用Update()方法

查阅Hibernate API(Hibernate_3.2.0_Reference_zh_CN.chm)得到Update()方法有:

update(Object object)
update(Object object, Serializable id)
update(String entityName, Object object)
update(String entityName, Object object, Serializable id)

 

很不幸运的事我的MyEclipse中只有一下方法(我用的是hibernate3.3.2,比API版本要高...我表示无语)

update(Object object)

update(String entityName, Object object)

 

测试代码:

	Teacher teacher = new Teacher();
		teacher.setId(4);
		teacher.setName("Marry");
		teacher.setBirthDate(new Date());
		
		SessionFactory sf = new AnnotationConfiguration().configure().buildSessionFactory();
		Session session = sf.getCurrentSession();
		session.beginTransaction();
                session.update(teacher);
		session.getTransaction().commit();
 
生成的Hibernate SQL 写道
update
_Teacher
set
birthDate=?,
name=?,
title=?
where
id=?

 数据库中结果:

  4 | 2011-04-13 19:52:52 | Marry | NULL

 

结论:使用Update()方法来更新数据得到的是数据对象的整体更新,不存在保留未修改选项,此方法不符合要求。

 

 

(2)使用Persistence 来更新

代码:

 

	SessionFactory sf = new AnnotationConfiguration().configure().buildSessionFactory();
		Session session = sf.getCurrentSession();
		session.beginTransaction();
		teacher = (Teacher)session.get(Teacher.class, 5);
		teacher.setName("Marry");
		session.getTransaction().commit();

生成SQL语句

update
        _Teacher
    set
        birthDate=?,
        name=?,
        title=?
    where
        id=?

 

数据库显示结果:

  5 | 2011-04-13 08:22:21 | Marrys | XX

 

结论:数据库中只修改了某一字段值,其余没有改变,符合要求。

 

 

(3)      延伸一下问题,若是使用persistence 来更新数据中的对象信息时Hibernate会发送全部字段的更新信息,有时候会降低效率,若是只发送需要修改的某一字段的信息?

      HQL语句 : Hibernate Quary Language 是Hibernate使用的面向对象的数据查询语言。

代码:

	Teacher teacher = new Teacher();
		
		SessionFactory sf = new AnnotationConfiguration().configure().buildSessionFactory();
		Session session = sf.getCurrentSession();
		session.beginTransaction();
		Query query = session.createQuery("update Teacher t set t.name='Toms' where t.id=5");
		query.executeUpdate();
		session.getTransaction().commit();
		

 Hibernate产生SQL语句:

 update
        _Teacher
    set
        name='Toms'
    where
        id=5

数据显示结果:

 5 | 2011-04-13 08:22:21 | Toms  | XX

 

结论:该方法同样可以满足实验要求,同时又能做到执行时候只发送需要修改字段的SQL语句,同时有使用到了HQL面向对象的语句,这种方法在项目中比较常用,是解决Update的首选方法。

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值