recherche

Maison  >  Questions et réponses  >  le corps du texte

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_lee2785 Il y a quelques jours633

répondre à tous(3)je répondrai

  • 迷茫

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

      Si
    1. mybatis est géré via la classe SqlSessionManager, alors chaque fil aura un SessionSession

      commun
    2. Dans ce plug-in intégré, une instruction de requête/mise à jour qui n'active pas les transactions correspond à un mybatis-spring Si une transaction est activée, les requêtes/mises à jour de cette transaction partagent toutes un <. 🎜> SessionSession Le

      dans
    3. n'est pas thread-safe, donc mybatisExecutorSession ne peut être réutilisé que dans un seul fil de discussion au maximum.

      répondre
      0
  • PHP中文网

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

    Bien sûr, une session peut opérer plusieurs DAO (y compris ajouter/supprimer/modifier/vérifier). Bien entendu, ces opérations DAO doivent répondre aux caractéristiques des transactions lorsque la session est soumise/annulée : soit toutes les modifications sont réussies, ou tous échouent. La seule restriction est la suivante : comme ils sont dans la même session, ces DAO doivent accéder à la même base de données.

    répondre
    0
  • 大家讲道理

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

    Oui, sauf comme mentionné ci-dessus, ces dao accèdent à la même base de données, veuillez noter que la session n'est pas thread-safe

    répondre
    0
  • Annulerrépondre