ホームページ  >  に質問  >  本文

java - Mybais 会话session是否公用

问题:使用mybatis时,一个sqlsessionfactory.opensession的方法,能否同时兼容多个dao的操作
例如,我在pojo a 的dao,aDAO的插入操作中,实例化了一个session,
SqlSession session = sqlSessionFactory.openSession();
ADAO aDAO = session.getMapper(ADAO.class);
此时由于我要同时对pojo b进行一些操作,那么我可不重新实例化新的session,而是直接使用之前实例的session a
BDAO bDAO = session.getMapper(BDAO.class)

如果可以这么操作的话,请问有什么限制(因为如果是删除,增加,更新的操作的话,是需要提交会话的,而查询不需要)

ringa_leeringa_lee2727日前593

全員に返信(3)返信します

  • 迷茫

    迷茫2017-04-17 18:00:32

    1. mybatisSqlSessionManager クラスを通じて管理される場合、各スレッドは共通の SessionSession

      を持ちます。
    2. この統合プラグインでは、トランザクションを有効にしないクエリ/更新ステートメントは mybatis-spring に対応します。トランザクションが有効な場合、このトランザクション内のクエリ/更新はすべて < を共有します。 🎜>SessionSession

    3. はスレッドセーフではないため、mybatisExecutorSession は最大でも 1 つのスレッドでのみ再利用できます。

      返事
      0
  • PHP中文网

    PHP中文网2017-04-17 18:00:32

    もちろん、セッションは複数の DAO (追加/削除/変更/チェックを含む) を操作できます。もちろん、これらの DAO 操作は、セッションが送信/ロールバックされるときのトランザクションの特性を満たす必要があります。つまり、すべての変更が成功するか、あるいはすべて失敗します。 唯一の制限は、これらの DAO は同じセッション内にあるため、同じデータベースにアクセスする必要があることです。

    返事
    0
  • 大家讲道理

    大家讲道理2017-04-17 18:00:32

    はい、上記の場合を除き、これらの DAO は同じデータベースにアクセスします。セッションはスレッドセーフではないことに注意してください

    返事
    0
  • キャンセル返事