使用hibernate Criteria更新多行

时间:2014-07-20 04:47:56

标签: java hibernate persistence

我正在尝试运行更新查询,在sql中看起来像这样:

update studentMaster set sess_status = 'G' where ACADEM_YEAR = COURSE_YEAR;

我正在尝试使用条件重新创建查询:

public void updateSessionStatus() {
        Session sess = factory.openSession();
        Transaction tx = null;
        try {
            tx = sess.beginTransaction();
            Criteria crit = sess.createCriteria(CollegeStudentsMaster.class);
            crit.add(Restrictions.eqProperty("academicYear", "courseYears"));
            CollegeStudentsMaster e = (CollegeStudentsMaster) crit.uniqueResult();
            e.setSessionStatus("G");
            sess.saveOrUpdate(e);
            tx.commit();
        } catch (HibernateException asd) {
            if (tx != null) {
                tx.rollback();
            }
            log.debug(asd.getMessage());
        } finally {
            sess.close();
        }
    }

这不起作用,因为满足此条件的行很多,我猜这个问题的唯一结果就是问题。 如何将其转换为符合条件的所有行的更新。我不想使用HQL查询,我宁愿使用Criteria。

1 个答案:

答案 0 :(得分:9)

public void updateSessionStatus() {
        Session sess = factory.openSession();
        Transaction tx = null;
        try {
            tx = sess.beginTransaction();
            Criteria crit = sess.createCriteria(CollegeStudentsMaster.class);
            crit.add(Restrictions.eqProperty("academicYear", "courseYears"));
            // Here is updated code
            ScrollableResults items = crit.scroll();
            int count=0;
            while ( items.next() ) {
                CollegeStudentsMaster e = (CollegeStudentsMaster)items.get(0);
                e.setSessionStatus("G");
                sess.saveOrUpdate(e);
                if ( ++count % 100 == 0 ) {
                    sess.flush();
                    sess.clear();
                }
            }
            tx.commit();
        } catch (HibernateException asd) {
            if (tx != null) {
                tx.rollback();
            }
            log.debug(asd.getMessage());
        } finally {
            sess.close();
        }
    }

始终建议执行非常接近数据库的批量操作,除非需要,否则我们不需要在会话中保留更新的对象,因此在执行批量操作时尽量避免在会话中加载对象。