使用hibernate进行批量更新和删除操作

本文中的功能仅存在于hibernate3中。参考文件hibernate3源代码中的org.hibernate.test.hql包下的BulkManipulationTest.java。

在hibernate2中对于批量操作的处理方法是,查询得到所有符合条件的数据库数据的主键,然后对根据主键对每条数据进行操作。这样感觉既费时又费力。最新Hibernate3中提供批量更新操作功能。例如:
程序代码 程序代码

String hqlUpdate = “ Update user u “+
“ SET u.username=:newUsername, u.password=:newPassword ”+
“ Where u.username=:username and u.password=:password “;
Query query = session.createQuery(hqlUpdate);
query.setString("username",”hfm”);
query.setString("password",”1”);
query.setString("newUsername",”ps”);
query.setString("newPassword",”123”);
int num = query.executeUpate();
ts.commit();


程序代码 程序代码

String hqlDelete = “ Delete FROM user u “+
“ Where u.username=:username and u.password=:password “;
query.setString("username",”ps”);
query.setString("password",”123”);
int num = query.executeUpate();
ts.commit();


变量session的类型为org.hibernate.Session;ts的类行为为org.hibernate.Transaction;返回值num表示有几条数据被操作了。以上两段代码执行后在控制台中打出来的SQL分别是:

Hibernate: update CUSTOMER user0_ set user0_.USERNAME=?, user0_.PASSWORD=? where (user0_.USERNAME=? and user0_.PASSWORD=?)

Hibernate: delete from CUSTOMER user0_ where (user0_.USERNAME=? and user0_.PASSWORD=?)

以上是我认为比较好的方法。但是注意,产生的第二条语句不能在MySql中执行,但是hql仍然可以被编译成sql,不知道是我语法写错了还是bug?有谁了解可以给我mail:lippea@sohu.com。另外在参考文件BulkManipulationTest.java中有一个方法:

public QueryTranslatorImpl assertTranslation(String hql) throws QueryException, MappingException;

这个方法我不知道是干嘛的,但是我尝试了按照这种形式进行批量操作:
程序代码 程序代码

String hqlDelete = “ Delete FROM user u “+
“ Where u.username=:username and u.password=:password “;
Object[] objects = new Object[]{“hfm”,”1”}
Type[] types=new Type[]{(Type)Hibernate.STRING,(Type)Hibernate.STRING};
QueryParameters queryParas = new QueryParameters(types,objects);
QueryTranslatorFactory ast = new ASTQueryTranslatorFactory();
QueryTranslator newQueryTranslator =
ast.createQueryTranslator(hqlDelete, Collections.EMPTY_MAP,
(SessionFactoryImplementor)sf );
newQueryTranslator.compile( Collections.EMPTY_MAP, false );
int num = newQueryTranslator.executeUpdate(queryParas,
(SessionImplementor)session);

sf的类型为org.hibernate.SessionFactory,session的类型为org.hibernate.Session。使用这种方法的结果与上面那种方法的结果相同,但是在对hql中变量进行赋值很不方便,我也没发现这种方法有什么更广泛的用处。或许有别的方法赋值,或者其它用处?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值