为PetaPoco添加Fill方法

来源:互联网 发布:人工智能如何硬件实现 编辑:程序博客网 时间:2024/06/18 18:17

为PetaPoco添加Fill方法

  因为公司框架中的很多地方用到DataTable,直接将DataTable作为数据源绑定到DataGridView,所以为PetaPoco添加了两个方法,一个是用以填充单个DataTable,一个是用以多结果集时填充DataSet。

复制代码
        #region operation Fill        /// <summary>        /// 填充一个DataSet        /// </summary>        /// <param name="ds">引用的DataSet</param>        /// <param name="sql">sql语句</param>        /// <param name="args">参数</param>        public void Fill(DataSet ds, string sql, params object[] args)        {            OpenSharedConnection();            try            {                using (var cmd = CreateCommand(_sharedConnection, sql, args))                {                    using (DbDataAdapter dbDataAdapter = _factory.CreateDataAdapter())                    {                        dbDataAdapter.SelectCommand = (DbCommand)cmd;                        dbDataAdapter.Fill(ds);                    }                }            }            finally            {                CloseSharedConnection();            }        }        /// <summary>        /// 填充一个DataTable        /// </summary>        /// <param name="dt">DataTable的引用</param>        /// <param name="sql">Sql语句</param>        /// <param name="args">参数</param>        public void Fill(DataTable dt, string sql, params object[] args)        {            OpenSharedConnection();            try            {                using (var cmd = CreateCommand(_sharedConnection, sql, args))                {                    using (DbDataAdapter dbDataAdapter = _factory.CreateDataAdapter())                    {                        dbDataAdapter.SelectCommand = (DbCommand)cmd;                        dbDataAdapter.Fill(dt);                    }                }            }            finally            {                CloseSharedConnection();            }        }        #endregion
复制代码

得到的DataTable可结合之前的一篇将DataTable转换为Json字符串的方法一起使用,无需转换实体,直接得到Json字符串,在前台使用。

转自:http://www.cnblogs.com/youring2/archive/2012/06/20/2556456.html

原创粉丝点击