- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用 Hibernate 5.1.0
的 Java 应用程序,具有在 Weblogic 12.1.1.0
和 上运行的空间功能 (
数据库。我有一些使用驱动程序 geolatte
) >Oracleoracle.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/
建立 OraConnection 的"new"方法是什么?Microsoft 将多个类定义为已过时。 https://msdn.microsoft.com/en-us/library/system.d
我会为更多查询重用 OracleConnection 对象所以我写了一个简单的类: public static class DbConnectionsManager { ///
将 java.sql.Connection 类型转换为 OracleConnection 与从 java.sql.Connection 展开方法获取 OracleConnection 有何不同。 另外
我正在升级一个使用连接池的类。特别是界面: oracle.jdbc.OracleConnection 现在这个接口(interface)有很多方法已经被弃用了。我只是想知道这个界面是否还有其他替代方案
我正在尝试从我的新 PC 连接到我的 Oracle 数据库。我刚刚安装了 Visual Studio 和 ODAC。但是,当我尝试进行简单的连接时,我收到一个异常消息、空源、空编号,错误代码为 -21
每次我尝试调试我的程序时都会收到此错误: CS0246: The type or namespace name 'OracleConnection' could not be found (are y
我遇到了一个在互联网上找不到的问题。 我正在尝试使用 ojdbc6 连接到数据库。我从 jndi 获取资源 使用方法 public OracleConnection getConnection()
我正在使用标准的 Oracle 驱动程序连接到数据库,但我不能真正同意我同事对 OracleConnection 生命周期的看法。创建成本高吗?它是线程安全的吗?我可以在请求之间重复使用它,还是应该为
我有一个使用 Hibernate 5.1.0 的 Java 应用程序,具有在 Weblogic 12.1.1.0 和 上运行的空间功能 (geolatte) >Oracle 数据库。我有一些使用驱动程
例如 OleDbConnection 与 OracleConnection、OleDbCommand 与 OracleCommand 等... 我知道 Oracle* 类适用于 Oracle DB,但
为什么不能在下面的代码中将 java.sql.Connection 转换为 oracle.jdbc.OracleConnection? 我的主要目标是将新用户名传递给 Oracle 连接并将其保存在“
对于我的测试,我需要模拟数据客户端,在我的例子中它们是 Oracle。 我已经创建了我的数据访问层以允许传入: public static Int32? GetUserRoleId(string us
我已经尝试过WSJDBCConnection does not wrap objects of type Oracle jdbc Connection中的解决方案 但它不起作用,所以请问如何从 tom
在连接到 Oracle11g 非 RAC 的 spring-mvc 项目中的 Jboss7.1.0EAP 中运行存储过程时,我有一段代码失败。我在 JBoss 独立版中使用了 ojdbc14.jar
我有一个 WebAPI 服务,它使用 Oracle.ManagedDataAccess.dll 连接到 Oracle 数据库。每次重置应用程序池(或部署)后,第一个 OracleConnection.
IOW,是否有对此进行测试的标准方法,a la: if (! con.Open()) con.Open(); ? 更新:我想我没有提到这些是我正在使用的 Oracle 的 ODP 组件。 Orac
我有一个 native C++ 应用程序,它需要连接到 Oracle 数据库。 Oracle 数据层是用 C# 编写的,所以我希望将代码作为 DLL 重用。 我决定尝试使用托管 C++ 来弥合 nat
如果在 catch 语句中发出 System.Environment.Exit(0),在“using” block 中是否关闭了 OracleConnection? 例子: Oracl
当我尝试在我的 C# 应用程序中连接到 Oracle 数据库并尝试单击一个按钮时,出现此错误: The type initializer for 'Oracle.DataAcces.Client.Or
我在下面代码的第一行得到异常 java.lang.ClassCastException: oracle.jdbc.internal.OracleConnection$$EnhancerByProxoo
我是一名优秀的程序员,十分优秀!