gpt4 book ai didi

java - 尝试检索 OracleConnection 但收到 null

转载 作者:行者123 更新时间:2023-12-01 10:03:50 26 4
gpt4 key购买 nike

我有一个使用 Hibernate 5.1.0 的 Java 应用程序,具有在 Weblogic 12.1.1.0 上运行的空间功能 (geolatte) >Oracle 数据库。我有一些使用驱动程序 oracle.jdbc.xa.client.OracleXADataSource 配置的数据源。这在一种环境中可以正常工作,但在另一种环境中则不行。运行查询时,我得到以下堆栈跟踪:

org.hibernate.HibernateException: java.lang.RuntimeException: Tried retrieving OracleConnection from weblogic.jdbc.wrapper.JTAConnection_weblogic_jdbc_wrapper_XAConnection_oracle_jdbc_driver_LogicalConnection using method getOriginalOwner, but received null.
at org.hibernate.spatial.dialect.oracle.SDOGeometryValueBinder.toNative(SDOGeometryValueBinder.java:88)
at org.hibernate.spatial.dialect.oracle.SDOGeometryValueBinder.bind(SDOGeometryValueBinder.java:53)
at org.hibernate.type.AbstractStandardBasicType.nullSafeSet(AbstractStandardBasicType.java:253)
(...)
Caused by: java.lang.RuntimeException: Tried retrieving OracleConnection from weblogic.jdbc.wrapper.JTAConnection_weblogic_jdbc_wrapper_XAConnection_oracle_jdbc_driver_LogicalConnection using method getOriginalOwner, but received null.
at org.geolatte.geom.codec.db.oracle.DefaultConnectionFinder.find(DefaultConnectionFinder.java:75)
at org.geolatte.geom.codec.db.oracle.OracleJDBCTypeFactory.createStruct(OracleJDBCTypeFactory.java:117)
at org.hibernate.spatial.dialect.oracle.SDOGeometryValueBinder.store(SDOGeometryValueBinder.java:72)

当我查看 Hibernate 调用的 geolatte-geom 库中的代码时,我看到 DefaultConnectionFinder.java如下:

    for ( Method method : con.getClass().getMethods() ) {
if ( method.getReturnType().isAssignableFrom(
java.sql.Connection.class
)
&& method.getParameterTypes().length == 0 ) {

try {
method.setAccessible( true );
final Connection oc = find( (Connection) ( method.invoke( con, new Object[] { } ) ) );
if ( oc == null ) {
throw new RuntimeException(
String.format(
"Tried retrieving OracleConnection from %s using method %s, but received null.",
con.getClass().getCanonicalName(),
method.getName()
)
);
}
return oc;
}

它获取 Weblogic 提供的连接包装器,并使用反射迭代所有可用的方法。它将尝试检索实际连接,寻找返回 java.sql.Connection.class 且不带输入参数的方法。

我的猜测是,大多数情况下找到的方法是 getConnection 但在这种情况下,由于 getMethods() 不按特定顺序返回值,因此可能的情况是 getOriginalOwner 方法先执行,该方法返回 null,然后发生异常。

我想我的问题是你是否认为我做错了什么,以及我如何避免这种情况,或者这是一个Hibernate错误,我应该在连接不为空时返回连接(当它为空时我会继续迭代)或类似的东西:

final Connection oc = find( (Connection) ( method.invoke( con, new Object[] { } ) ) );
if ( oc != null ) {
return oc;
}

最佳答案

参见http://www.hibernatespatial.org/documentation/03-dialects/05-oracle/了解 ConnectionFinder 接口(interface)的用途。

如果 DefaultConnectionFinder 在您的环境中不起作用,您应该创建自己的实现来返回正确的 OracleConnection 实例,并使用 hibernate.spatial.connection_finder 配置属性对其进行配置。

关于java - 尝试检索 OracleConnection 但收到 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36605859/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com