EJB3 DataSource DataSource.getConnection

 mobiledu2502875803 发布于 2022-12-08 19:01

在CMT J2EE环境(容器管理事务)中,当我JDNI查找DataSource对象并调用时,使用什么事务/连接DataSource.getConnection

这个连接是(可能是分布式的)交易的一部分吗?getConnection()每次我为同一个DataSource对象调用它时,是否返回相同的Connection?我只知道使用本机SQL语句由同一个EntityManager使用Connections.

这让我感到困惑.据我所知,SessionContext定义了一个每次使用数据源时都使用的事务系统.我有一个问题,在使用会话bean a DataSource.getConnection(),然后关闭此连接.如果遇到问题SessionContext.setForRollBack(true)则发出.

因此,服务的事务上下文如何与DataSource相关?

如果我们每次使用数据源或者至少查找数据源时都会生成一个新的连接,那么我就无法理解我已经知道的事情.任何澄清都会很精彩.我知道容器管理的事务和其他系统,但DataSource的实际行为完全超出了我.

1 个回答
  • 在Java EE中,事务是一种不是数据库专有的概念,例如JMS连接会话也可以是容器管理事务的一部分.这个想法是,如果在容器管理的事务边界下运行一个或多个方法,容器将根据需要提交或回滚事务.

    在数据库相关的数据源中,有多个层,第一个是由容器维护的连接的托管池,第二个是数据库驱动程序与数据库的实际连接管理,在Java中,Connection是会话的抽象使用数据库而不是物理连接,由驱动程序管理.

    有了上述背景,您的问题可以解决,即:

    当我JDNI查找DataSource对象并调用DataSource.getConnection时使用什么事务/连接.

    在容器管理事务下,虽然它是依赖于实现的,但是与数据库的连接/会话关联,并用事务边界标记.驱动程序可以与数据库共享实际的物理连接,但这对应用程序和容器都是透明的.

    这个连接是(可能是分布式的)交易的一部分吗?每次我为同一个DataSource对象调用它时,getConnection是否返回相同的Connection?

    请参阅上面的内容,Connection与驱动程序打开的数据库底层套接字无关.它在逻辑上是一个单独的会话,如果在事务边界内,相同的会话与从数据源检索的连接相关联,这是如何实现的是容器设计的一部分

    我有一个问题,在会话bean内部使用DataSource.getConnection,然后关闭此连接

    在连接的池化实现中,Connection.close()没有影响,连接将返回到池中(http://commons.apache.org/proper/commons-dbcp/api-1.3/org/apache/commons/ dbcp/PoolableConnection.html),这种行为对所有池都类似.因此,虽然不应在容器管理的事务中关闭连接,但是,连接不一定取消它与容器事务边界的关联.同样,不能从CMT中调用commit,setAutoCommit,rollback,因为这将发出相当于实际数据库的以下命令,之后的事务行为将是未定义的.

    2022-12-11 03:08 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有