gpt4 book ai didi

c# - ODP.NET 托管驱动程序在连接到 Oracle 数据库时抛出异常

转载 作者:行者123 更新时间:2023-11-30 20:52:55 24 4
gpt4 key购买 nike

你好,

我正在开发一个使用 NHibernate + ODP.NET 托管驱动程序的 c# 应用程序,应用程序在连接期间抛出异常:

[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 数据库 11g 企业版发布 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 非托管它也能正常工作!使用 Oracle Client (System.Data.OracleClient) 也可以正常工作!

可能有人知道如何解决这个问题?谢谢!

最佳答案

问题出在非标准数据库编码中。要解决此问题,您应该在数据库中使用标准编码(将数据库中的非标准编码转换为标准编码 (UTF8))。

关于c# - ODP.NET 托管驱动程序在连接到 Oracle 数据库时抛出异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20417512/

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