hibernate3 的常用操作(批量刪除,批量插入,關聯查詢)
1 批量刪除是調用sql引擎執行sql語句。批量插入有兩種方式,a:自己拼接出一條sql語句 b:利用hibernate的session一級緩存,每多少條刷新緩存存入數據庫
@Component
public class StudentDao extends HibernateDao<Student, Integer> {
public void deleteByIds(List<?> ids) {
String hql = "delete from Student where id in (:ids)";
createQuery(hql).setParameterList("ids", ids).executeUpdate();
}
public void saveBatch(List<Student> stuList) {
if (null != stuList && stuList.size() > 0) {
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
try {
for (int i = 0; i < stuList.size(); i++) {
session.save(stuList.get(i));
if (i % 100 == 0) { // 每一百條刷新并寫入數據庫
session.flush();
session.clear();
}
}
} catch (HibernateException e) {
e.printStackTrace();
}finally{
tx.commit();
session.close();
}
}
}
}
//批量查詢,當然hibernate也提供了使用某一個屬性查詢出集合
String hql = "from Goods where merchandiseId in (:ids)";
List<Goods> goodsList = goodsDao.createQuery(hql).setParameterList("ids", idList).list();</pre>
2 批量插入采用sql時如下:
public void setMappingGoods(Integer merchandiseId,List<Integer> ids) {
StringBuilder sb = new StringBuilder();
sb.append("insert into mapping_goods(kid,oid) values ");
for(Integer id:ids){
sb.append("("+merchandiseId+","+id+")"+",");
}
goodsmapDao.getSession().createSQLQuery(sb.substring(0, sb.length()-1)).executeUpdate();
}
3 hql 關聯查詢:當沒有在實體中設置關聯關系,而是自己建立的中間表時,可以用hql關聯查詢數據。
public List<Goods> getMappingGoods(String kuuid) {
if(StringUtils.empty(kuuid)){
return new ArrayList<Goods>();
}
String hql = " from Goods g where g.merchandiseUuid!=? and ( (g.merchandiseUuid in (select mp.kuuid from Goodsmap mp where mp.kuuid=? or mp.ouuid=?)) or (g.merchandiseUuid in (select mp.ouuid from Goodsmap mp where mp.kuuid=? or mp.ouuid=?)))";
return goodsDao.find(hql,kuuid, kuuid,kuuid, kuuid,kuuid);
}
本文由用戶 xmnx 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!