2

良い一日、

NHibernate + ODP.NET Managed Driver を使用する ac# アプリケーションを開発していますが、接続中にアプリケーションが例外をスローします。

[06.12.2013 12:29:33:324] NHibernate.Exceptions.GenericADOException : could not execute query
   at NHibernate.Loader.Loader.ListIgnoreQueryCache(ISessionImplementor session, QueryParameters queryParameters)
   at NHibernate.Loader.Criteria.CriteriaLoader.List(ISessionImplementor session)
   at NHibernate.Impl.SessionImpl.List(CriteriaImpl criteria, IList results)
   at NHibernate.Impl.CriteriaImpl.List(IList results)
   at NHibernate.Impl.CriteriaImpl.List[T]()
   ...
[Inner Exception] System.ArgumentNullException : Parameter '' cannot be null.
Parameter name: serializationStream
   at OracleInternal.ConnectionPool.PoolManager`3.CreateNewPR(Int32 reqCount, Boolean bForPoolPopulation, ConnectionString csWithDiffOrNewPwd, String instanceName)
   at OracleInternal.ConnectionPool.PoolManager`3.Get(ConnectionString csWithDiffOrNewPwd, Boolean bGetForApp, String affinityInstanceName, Boolean bForceMatch)
   at OracleInternal.ConnectionPool.OraclePoolManager.Get(ConnectionString csWithNewPassword, Boolean bGetForApp, String affinityInstanceName, Boolean bForceMatch)
   at OracleInternal.ConnectionPool.OracleConnectionDispenser`3.Get(ConnectionString cs, PM conPM, ConnectionString pmCS, SecureString securedPassword, SecureString securedProxyPassword)
   at Oracle.ManagedDataAccess.Client.OracleConnection.Open()
   at NHibernate.Connection.DriverConnectionProvider.GetConnection()
   at NHibernate.AdoNet.ConnectionManager.GetConnection()
   at NHibernate.AdoNet.AbstractBatcher.Prepare(IDbCommand cmd)
   at NHibernate.AdoNet.AbstractBatcher.ExecuteReader(IDbCommand cmd)
   at NHibernate.Loader.Loader.GetResultSet(IDbCommand st, Boolean autoDiscoverTypes, Boolean callable, RowSelection selection, ISessionImplementor session)
   at NHibernate.Loader.Loader.DoQuery(ISessionImplementor session, QueryParameters queryParameters, Boolean returnProxies)
   at NHibernate.Loader.Loader.DoQueryAndInitializeNonLazyCollections(ISessionImplementor session, QueryParameters queryParameters, Boolean returnProxies)
   at NHibernate.Loader.Loader.DoList(ISessionImplementor session, QueryParameters queryParameters)

ソフトウェアバージョン:

Oracle Database 11g Enterprise Edition リリース 11.2.0.1.0 - 64 ビット製品

ODP.NET 管理対象ドライバー バージョン 121.1.1

他のOracleデータベース: 「Oracle Database 11g Release 11.2.0.3.0 - 64bit Production」では正常に動作しています!

Oracle ODP.NET unmanaged でも問題なく動作しています。Oracle クライアント (System.Data.OracleClient) でも問題なく動作しています。

誰かがそれを修正する方法を知っているかもしれませんか?ありがとう!

4

1 に答える 1

4

問題は、非標準のデータベース エンコーディングにありました。この問題を解決するには、データベースで標準エンコーディングを使用する必要があります (データベースの非標準エンコーディングを標準 (UTF8) に変換します)。

于 2013-12-23T07:44:49.563 に答える