hibernate3批量删除的HQL语句

String hqlDelete = "delete users u where u.name = :name and u.user.id = :id"
int deletedEntities = s.createQuery( hqlDelete )
    .setString( "name", name )
    .setString( "id", id )
    .executeUpdate();

 

Hibernate3.0对批量更新和批量删除提供了支持,能够直接执行批量更新或批量删除语句,无需把被更新或删除的对象先加载到内存中。以下是通过Hibernate3.0执行批量更新的程序代码:

代码
  1. Session session = sessionFactory.openSession();    
  2. Transaction tx = session.beginTransaction();    
  3. String hqlUpdate = "update Customer set name = :newName where name =:ldName";    
  4. int updatedEntities = s.createQuery( hqlUpdate )    
  5. .setString( "newName", newName )    
  6. .setString( "oldName", oldName )    
  7. .executeUpdate();    
  8. tx.commit();    
  9. session.close();   

以下是通过Hibernate3.0执行批量删除的程序代码:

代码
  1. Session session = sessionFactory.openSession();    
  2. Transaction tx = session.beginTransaction();    
  3. String hqlDelete = "delete Customer where name = :ldName";    
  4. int deletedEntities = s.createQuery( hqlDelete )    
  5. .setString( "oldName", oldName )    
  6. .executeUpdate();    
  7. tx.commit();    
  8. session.close();   

 

 

Hibernate3.0取消了以往的session.delete(sql)的批量删除方法(原版被取消的方法可以在org.hibernate.classic包内找到原版的Session类)
那么,hibernate3.0实现批量方式的方法为:
public void cleanCMHistory(Date date) {
 
        Session session = getSession();
        Transaction tx = session.beginTransaction();
 
        try {
 
            String hqlDelete = "delete CMInfo where timeStamp < :cleanTime";
 
            int deletedEntities = session.createQuery(hqlDelete).setTimestamp(
                "cleanTime", date).executeUpdate();
                     //先查询出符合条件的结果集,再将其置空
                     //此事例删除where子句判定列为timestamp类型,故使用setTimestamp,其他
                     //类型应调用相应的set方法
            tx.commit();
 
        }
        catch (Exception ex) {
            log.info(ex);
            tx.rollback();
        }
        session.close();
 
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值