suliuyes 2011-10-09 15:39
浏览 231
已采纳

用hibernate如何批量删改操作?(内详)

我看了下文档,批量删改的话 ,有两种:
一种是批量操作的实体们有共同部分,就可以用HQL语句来一次性执行。
二种是实体数据没有共同部分,就用for循环,注意清理session缓存。

请问第二种情况,我觉得用for循环感觉比较别扭而且也担心性能问题。 是否还有解决办法?

  • 写回答

2条回答

  • AngelAndAngel 2011-10-09 15:53
    关注

    第二种方法没太大问题的,即使性能可能有问题也不是for引起的。而且不必每次循环都清理缓存,可以每添加n个清理一次,下面是示例代码,你看下。
    [code="java"]
    Session session=HibernateUtil.currentSession();
    Transatcion tx=session.beginTransaction();
    for(int i=0;i<10000;i++)
    {
    Student st=new Student();
    st.setName(“feifei”);
    session.save(st);
    // 以每50个数据作为一个处理单元
    if(i%50==0)

    {
    // 只是将Hibernate缓存中的数据提交到数据库,保持与数据库数据的同步
    session.flush();

    // 清除内部缓存的全部数据,及时释放出占用的内存
    session.clear();

    }
    }
    tx.commit();

    [/code]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 求数学坐标画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站