5

当我在 Oracle 应用服务器 10.1.3 和 Oracle10g 中部署的应用程序中运行查询时,我看到了一些奇怪的东西。

当我直接对数据库运行语句时(例如,调用使用休眠实现的 DAO 的独立应用程序),我看到以下内容:

select 
    documentco0_.CONTENT_ID as CONTENT1_63_0_, 
    documentco0_.TSTAMP as TSTAMP63_0_, 
    documentco0_.CONTENT as CONTENT63_0_ 
from 
    MySchema.MyTable documentco0_ 
where 
    documentco0_.CONTENT_ID=? 

[main] TRACE org.hibernate.type.LongType - binding '1768334' to parameter: 1 
[main] TRACE org.hibernate.type.TimestampType - returning '2013-08-05 17:31:32' as     column: TSTAMP63_0_ 
[main] TRACE org.hibernate.type.BinaryType - returning '7f587f608090cac6c9c68081818180b380b380807f5b80c3807f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f7f40808b8880918091818191807f44809f8080818581818181818180808080808080808182838485868788898a8b7f44803590808281838382848385858484808081fd8182838084918592a1b1c18693d1e187a2f194b201112188a3c2314195d25170a4b3e2f202898a969798999aa5a6a7a8a9aab4b5b6b7b8b9bac3c4c5c6c7c8c9cad3d4d5d6d7d8d9dae3e4e5e6e7e8e9eaf3f4f5f6f7f8f9fa030405060708090a12131415161718191a22232425262728292a32333435363738393a42434445464748494a52535455565758595a6162636465666768696a7172737475767778797a7f5a808881818080bf80fef947bf520c730eff25ada7bd007c7f807a460efd87677f805625220aab7f59' as column: CONTENT63_0_ 

但是,在应用程序服务器中运行时,相同的 DAO 操作会返回以下内容:

select 
    documentco0_.CONTENT_ID as CONTENT1_63_0_, 
    documentco0_.TSTAMP as TSTAMP63_0_, 
    documentco0_.CONTENT as CONTENT63_0_ 
from 
    MySchema.MyTable documentco0_ 
where 
    documentco0_.CONTENT_ID=? 

2013-08-06 12:49:46,484 TRACE [AJPRequestHandler-RMICallHandler-12] myuser:4 (NullableType.java:133 nullSafeSet()) - binding '1768334' to parameter: 1 
2013-08-06 12:49:46,500 TRACE [AJPRequestHandler-RMICallHandler-12] myuser:4 (NullableType.java:172 nullSafeGet()) - returning '2013-08-05 17:31:32' as column: TSTAMP63_0_ 
2013-08-06 12:49:46,500 TRACE [AJPRequestHandler-RMICallHandler-12] myuser:4 (NullableType.java:172 nullSafeGet()) - returning '80d48081818c808080818080808180808099ff0c809a5c9d809a5c9c80828082808080817f587f608090cac6c9c68081808080804818f7ef8081808080808080808080808080808080808080809a5c9c83408c508081' as column: CONTENT63_0_ 

您可以看到标识符和时间戳在两种情况下都相同,但内容 blob 不同:第一种情况为 360 字节,第二种情况为 86 字节。

独立应用程序使用BasicDataSource,而服务器上的应用程序使用 JNDI 数据源。我已经验证了BasicDataSource包含在 JNDI 数据源中使用的相同 JDBC url。两个数据源使用相同的凭据。

应用服务器中的数据库操作有不同的跟踪输出,NullableType::nullSafeGet()用于显示信息而不是org.hibernate.type跟踪。我不确定这是否相关。

我在这里忽略了什么明显的东西吗?我不明白为什么在同一个数据库上运行相同的查询时会得到不同的结果。

编辑:在 OAS 上,我配置了一个使用连接工厂类的 JDBC ConnectionPool,oracle.jdbc.pool.OracleDataSource而 JDBC 数据源是指向该连接池的托管数据源。

我在想不同的 Oracle JDBC 驱动程序可能存在问题?BasicDataSource独立应用程序使用 JDBC 驱动程序和oracle.jdbc.driver.OracleDriver方言org.hibernate.dialect.Oracle10gDialect。我在 OAS 管理中看不到任何显示等效值的地方。

4

1 回答 1

1

请看看这篇文章

看起来,出于某种原因,OAS 只返回 86 个字节的 BLOB 值,除非您在配置中指定 Lob 处理程序。

您还可以在CodeRanch的这个线程上获得更多信息,描述相同的问题

希望这可以帮助!

于 2013-08-06T04:10:41.890 回答