NHibernate 2.x应用: 返回DataSet

虽然NHibernate是完全OO的,但我们还是有需要返回DataSet的时候。

在ADO.NET里,要返回DataSet需要使用IDbDataAdapter, 那么通过NHibernate返回DataSet的关键就是如何创建合适的IDbDataAdapter实现类。

在NHibernate里,由IDriver负责创建Connection和Command,我们可以扩展相应的Driver使其能创建DataAdapter,对于SqlClientDriver的扩展类如下:
    public class ExSqlClientDriver : SqlClientDriver
    {
        public IDbDataAdapter CreateDataAdapter()
        {
            return new SqlDataAdapter();
        }
    }

对应的配置更改如下:
 <property name="connection.driver_class">Chapter01.ExSqlClientDriver, Chapter01</property>

主调用代码:
 // 初始化
 Configuration cfg = new Configuration().Configure();
 ISessionFactory sf = cfg.BuildSessionFactory();
 // 得到扩展的Driver
 ExSqlClientDriver driver = (ExSqlClientDriver)sf.ConnectionProvider.Driver;
 // 打开数据库连接
 IDbConnection conn = ((ISessionFactoryImplementor)sf).OpenConnection();
 // 创建Command
 IDbCommand cmd = conn.CreateCommand();
 cmd.CommandText = "select * from infos";
 DataSet ds = new DataSet();
 // 创建DataAdapter
 IDbDataAdapter da = driver.CreateDataAdapter();
 da.SelectCommand = cmd;
 // 填充Dataset
 da.Fill(ds);

<script src="http://www.cchensoft.com/gad/blog_csdn_article.js" type=text/javascript></script>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值