Erro com NHibernate 2.1 e Oracle 10g cliente
-
06-07-2019 - |
Pergunta
Eu preciso para obter NHibernate 2.1 de falar com um banco de dados Oracle. Estou sendo obrigado a usar o cliente do Oracle 10g. Eu recebo o seguinte erro ao tentar construir minha fábrica de sessão:
Não é possível para objeto elenco de tipo 'Oracle.DataAccess.Client.OracleConnection' digitar 'System.Data.Common.DbConnection'.
Não me lembro recebendo este erro com NHibernate 2.01. Eu estou tentando obter os administradores de servidores para instalar o cliente 11g, mas parece que é uma batalha perdida.
Aqui estão os bits importantes do meu 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>
rastreamento de pilha completa ??p>
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
Solução
Eu fiz esta mesma pergunta no grupo NHUsers, e obteve uma resposta aceitável. Adicione o seguinte à configuração do hibernate:
<property name="hbm2ddl.keywords">none</property>
http://fabiomaulo.blogspot.com/2009 /06/auto-quote-tablecolumn-names.html