为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


本文转自齐师傅博客园博客,原文链接:http://www.cnblogs.com/youring2/archive/2012/06/20/2556456.html如需转载请自行联系原作者
相关文章
|
6月前
|
Android开发
解决RenderUiKitView object was given an infinite size during layout.
解决RenderUiKitView object was given an infinite size during layout.
53 3
|
9月前
|
前端开发
line-height与height的区别
line-height与height的区别
86 0
|
前端开发
今天来讲讲 scale、translate 和 rotate 这三个属性,你不会以为我是要讲的是 transform 吧?
总所周知,transform 是 CSS3 中最强大的属性之一,它有这么三个函数属性值:scale、translate 和 rotate,它们分别是缩放、位移和旋转,但是你有没有想过有这么一天它们三个
366 0
今天来讲讲 scale、translate 和 rotate 这三个属性,你不会以为我是要讲的是 transform 吧?
|
前端开发
opacity和background的rgba区别
opacity和background的rgba区别
ListView列宽自适应,设置ListView.Column[0].Width := -1;
使用TListView列表显示内容,如果列内容过长,就会显示成‘XXX…’形式,此时如果双击列标题,列宽将变为自适应。用代码设置如下: 1、设置ListView.Column[0].Width := -1;//列宽根据列内容自适应,此时保证列内容都可见。
3147 0
fbh
less学习——Color 函数
LESS 提供了一系列的颜色运算函数. 颜色会先被转化成 HSL 色彩空间, 然后在通道级别操作: lighten(@color, 10%); // return a color which is 10% *li...
fbh
1385 0