中国资深步行专家 2013-04-28 14:52
浏览 270
已采纳

Auto的fulshMode,为什么查询前不自动清理缓存呢?

如下代码,flushMode是auto,为什么在执行query.lst() 的select时没有先自动执行user1入库的insert语句。
按照auto的FulshMode,应该在查询前,flush时,、commit时进行缓存清理的啊。

[code="java"]System.out.println("flushMode="+session.getFlushMode());
//Transaction tx=session.beginTransaction();

        User user1=new User();
        user1.setUserID(13000000);
        user1.setUserName("wa1");
        session.save(user1);



        Query query = session.createQuery("from query.common.User");
        List lst=query.list();

[/code]

  • 写回答

2条回答

  • jinnianshilongnian 2013-05-03 13:58
    关注

    [url]https://hibernate.atlassian.net/browse/HHH-1410[/url]

    When operating outside a transaction, FlushMode.AUTO is a bad thing.
    Two options here:
    1) no-op the autoFlush processing when outside a transaction
    2) explicitly manage the Session's FlushMode setting when outside a transaction
    #1 seems more viable, since Session.setFlushMode() might cause problems (or at least extra complexity) with #2

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

报告相同问题?

悬赏问题

  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题