摘要
NHibernate2.1.1版终于可以调用Oracle的存储过程了,不过必须使用NHibernate.Driver.OracleDataClientDriver驱动(Oracle.DataAccess.dll),但这会导致hbm2ddl.keywords抛异常,所以也不是很完美。
NHibernate调用Oracle的存储过程的方法
首先,在Oracle10g里面创建一个简单的存储过程,它的第一个参数必须是SYS_REFCURSOR类型的。
存储过程 Customer表结构如下。
Customer表结构 在Customer.hbm.xml里面,增加调用存储过程的配置。
<sql-query name="SelectCustomerByName">
<return alias="cus" class="Dawn.HIS.Infrastructure.Core.Li.Customer">
</return>
{ call spCustomer_get_by_name(:customer_name) }
</sql-query> 调用存储过程的C#代码为:
ISession session =
IQuery q = session.GetNamedQuery("SelectCustomerByName");
q.SetString("customer_name", "景");
IList<Customer> cList = q.List<Customer>();
现在已经可以运行下试试了,不过很可能会抛出“OracleClientDriver does not support CallableStatement syntax (stored procedures). Consider using OracleDataClientDriver instead.”这个异常,如果你和我一样用的是“NHibernate.Driver.OracleClientDriver”的话。解决方法是,在hibernate.cfg.xml文件里把“<property name="connection.driver_class">NHibernate.Driver.OracleClientDriver</property>”改成“<property name="connection.driver_class">NHibernate.Driver.OracleDataClientDriver</property>”,然后把“Oracle.DataAccess.dll”(在Oracle客户端的安装目录下可以找到它)复制到网站的bin目录下。
再次运行程序,会抛出“无法将类型为“Oracle.DataAccess.Client.OracleConnection”的对象强制转换为类型“System.Data.Common.DbConnection”。 ”异常。引发这个异常的是“NHibernate\Tool\hbm2ddl\SuppliedConnectionProviderConnectionHelper.cs”。第25行:“connection = (DbConnection)provider.GetConnection();”。有一个方法可以绕过这行代码的执行,就是在hibernate.cfg.xml里增加一行“<property name="hbm2ddl.keywords">none</property>”。但其实“hbm2ddl.keywords”是一个挺不错的功能(有兴趣可以Google下这个关键字),不能用它挺遗憾的,而且也不知道除了这个之外是否还有其它功能会受到影响,心里毛毛的。
除了上面的演示,还可以调用Oracle的Function获取数据,也可以调用存储过程进行增、删、改操作,请参考“NHibernate-2.1.1.GA-src\src\NHibernate.Test\SqlTest\Custom\Oracle”目录下的源代码。
NHibernate2.1.1版终于可以调用Oracle的存储过程了,不过必须使用NHibernate.Driver.OracleDataClientDriver驱动(Oracle.DataAccess.dll),但这会导致hbm2ddl.keywords抛异常,所以也不是很完美。
NHibernate调用Oracle的存储过程的方法
首先,在Oracle10g里面创建一个简单的存储过程,它的第一个参数必须是SYS_REFCURSOR类型的。











现在已经可以运行下试试了,不过很可能会抛出“OracleClientDriver does not support CallableStatement syntax (stored procedures). Consider using OracleDataClientDriver instead.”这个异常,如果你和我一样用的是“NHibernate.Driver.OracleClientDriver”的话。解决方法是,在hibernate.cfg.xml文件里把“<property name="connection.driver_class">NHibernate.Driver.OracleClientDriver</property>”改成“<property name="connection.driver_class">NHibernate.Driver.OracleDataClientDriver</property>”,然后把“Oracle.DataAccess.dll”(在Oracle客户端的安装目录下可以找到它)复制到网站的bin目录下。
再次运行程序,会抛出“无法将类型为“Oracle.DataAccess.Client.OracleConnection”的对象强制转换为类型“System.Data.Common.DbConnection”。 ”异常。引发这个异常的是“NHibernate\Tool\hbm2ddl\SuppliedConnectionProviderConnectionHelper.cs”。第25行:“connection = (DbConnection)provider.GetConnection();”。有一个方法可以绕过这行代码的执行,就是在hibernate.cfg.xml里增加一行“<property name="hbm2ddl.keywords">none</property>”。但其实“hbm2ddl.keywords”是一个挺不错的功能(有兴趣可以Google下这个关键字),不能用它挺遗憾的,而且也不知道除了这个之外是否还有其它功能会受到影响,心里毛毛的。
除了上面的演示,还可以调用Oracle的Function获取数据,也可以调用存储过程进行增、删、改操作,请参考“NHibernate-2.1.1.GA-src\src\NHibernate.Test\SqlTest\Custom\Oracle”目录下的源代码。

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· Open-Sora 2.0 重磅开源!