Hibernate HQL示例十二:DML更新、删除及与Hibernate持久化更新

DML更新及删除

示例:

package com.bjsxt.hibernate;

import junit.framework.TestCase;

import org.hibernate.Query;
import org.hibernate.Session;

public class DMLQueryTest extends TestCase {
	
	public void testQuery1() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			session.beginTransaction();
			/**
			 * 使用这种风格的操作,将会造成内存中的对象与数据库中的数据不同步,所以
			 * 建议尽量少使用:因为hibernate有一级缓存,而更新不更新缓存的数据,只是更新了数据库的数据。
			 * 应尽量用hibernate的update操作
			 */
			Query updateQuery =  session.createQuery("update Student a set a.name=? where a.id in(:ids)");
			updateQuery.setParameter(0, "张三");
			updateQuery.setParameterList("ids", new Object[]{1, 2});
			updateQuery.executeUpdate();
			
			
			session.getTransaction().commit();
		}catch(Exception e) {
			e.printStackTrace();
			session.getTransaction().rollback();
		}finally {
			HibernateUtils.closeSession(session);
		}				
	}
	
	public void testQuery2() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			session.beginTransaction();
			
//			Query updateQuery =  session.createQuery("delete from Student s where s.id='1'");
			Query updateQuery =  session.createQuery("delete from Student s where s.id=?").setParameter(0, 2);
			updateQuery.executeUpdate();
			
			session.getTransaction().commit();
		}catch(Exception e) {
			e.printStackTrace();
			session.getTransaction().rollback();
		}finally {
			HibernateUtils.closeSession(session);
		}				
	}
}

 

我们要更新数据或删除数据,一般会先通过load/get/list查询等使对象进入持久状态,然后直接调用set方法更改属性,hibernate会自动发出一条更新语句进行更新操作。如

public void testQuery3() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			session.beginTransaction();
			List list = session.createQuery("select s from Student s where s.id=3").list();
			for (Iterator iterator = list.iterator(); iterator.hasNext();) {
				Student object = (Student) iterator.next();
				System.out.println(object.getName());
				object.setName("yeyeyeye");
				
			}
			session.getTransaction().commit();
		}catch(Exception e) {
			e.printStackTrace();
			session.getTransaction().rollback();
		}finally {
			HibernateUtils.closeSession(session);
		}				
	}

 

上例中查询出来的name值的Student对象进入持久状态,马上调用了setName方法执行时的sql:

Hibernate: select student0_.id as id1_, student0_.name as name1_, student0_.createTime as createTime1_, student0_.classid as classid1_ from t_student student0_ where student0_.id=3
gooooeeeeood
Hibernate: update t_student set name=?, createTime=?, classid=? where id=?
上面:gooooeeeeood为原来的name值,再次查询数据库时name变成了yeyeyeye

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值