oracle - NHibernate 2.1 和 Oracle 10g 客户端出错

标签 oracle nhibernate oracle10g

我需要让 NHibernate 2.1 与 oracle 数据库对话。我需要使用 Oracle 10g 客户端。尝试构建 session 工厂时出现以下错误:

Unable to cast object of type 'Oracle.DataAccess.Client.OracleConnection' to type 'System.Data.Common.DbConnection'.



我不记得在 NHibernate 2.01 中遇到过这个错误。我试图让服务器管理员安装 11g 客户端,但看起来这是一场失败的战斗。

以下是我的 web.config 中的重要部分:
<runtime>
  <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
    <qualifyAssembly partialName="Oracle.DataAccess" fullName="Oracle.DataAccess, Version=10.2.0.100, Culture=Neutral, PublicKeyToken=89b483f429c47342"/>    
  </assemblyBinding>
</runtime>
<hibernate-configuration xmlns="urn:nhibernate-configuration-2.2">
 <session-factory>
   <property name="dialect">NHibernate.Dialect.Oracle10gDialect</property>
   <property name="connection.provider">NHibernate.Connection.DriverConnectionProvider</property>
   <property name="connection.driver_class">NHibernate.Driver.OracleDataClientDriver</property>
   <property name="connection.connection_string_name">Demo</property>
   <property name="show_sql">false</property>
   <property name="proxyfactory.factory_class">NHibernate.ByteCode.Castle.ProxyFactoryFactory, NHibernate.ByteCode.Castle</property>
  </session-factory>
</hibernate-configuration>

完整的堆栈跟踪
at NHibernate.Tool.hbm2ddl.SuppliedConnectionProviderConnectionHelper.Prepare()
at NHibernate.Tool.hbm2ddl.SchemaMetadataUpdater.GetReservedWords(Dialect dialect, IConnectionHelper connectionHelper)
at NHibernate.Tool.hbm2ddl.SchemaMetadataUpdater.Update(ISessionFactory sessionFactory)
at NHibernate.Impl.SessionFactoryImpl..ctor(Configuration cfg, IMapping mapping, Settings settings, EventListeners listeners)
at NHibernate.Cfg.Configuration.BuildSessionFactory()
at ConsoleApplication6.Program.Main(String[] args) in C:\\Dev\\Temp\\ConsoleApplication6\\Program.cs:line 26

最佳答案

我在 NHUsers 组中问了同样的问题,并得到了可以接受的答案。
将以下内容添加到休眠配置中:

<property name="hbm2ddl.keywords">none</property>

http://fabiomaulo.blogspot.com/2009/06/auto-quote-tablecolumn-names.html

关于oracle - NHibernate 2.1 和 Oracle 10g 客户端出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1210037/

相关文章:

c# - NHibernate 映射索引超出范围

c# - 处理这段关系的最佳方式

sql-server-2008 - SSMA 或 SSIS,用于从 Oracle 10 迁移到 SQL Server 2008 R2

oracle - Oracle 加密和 SSL 有什么区别

oracle - PL/SQL : Any trick to avoid cloning of objects?

sql - 将 sql View 查询更改为关系代数?

database - Oracle 数据库中表触发器的多模式权限

sql - Oracle Apex 数据加载

c# - "An invalid or incomplete configuration was used while creating a SessionFactory"Web 服务中的 NHibernate

java - Hibernate - 编写查询所需的帮助