为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如需转载请自行联系原作者
相关文章
|
JavaScript
background-color设置为透明的方法
background-color设置为透明的方法
174 0
|
前端开发
opacity和background的rgba区别
opacity和background的rgba区别
|
前端开发
今天来讲讲 scale、translate 和 rotate 这三个属性,你不会以为我是要讲的是 transform 吧?
总所周知,transform 是 CSS3 中最强大的属性之一,它有这么三个函数属性值:scale、translate 和 rotate,它们分别是缩放、位移和旋转,但是你有没有想过有这么一天它们三个
323 0
今天来讲讲 scale、translate 和 rotate 这三个属性,你不会以为我是要讲的是 transform 吧?
|
Web App开发 前端开发
给Img标签设置height和width属性
给Img标签设置height和width属性
723 0
Error:top-left corner pixel must be either opaque white or transparent.
Error:top-left corner pixel must be either opaque white or transparent. Information:Gradle tasks [:app:assembleDebug] Error:to...
2805 0
$ gradle packageDebug --stacktrace error: top-left corner pixel must be either opaque white or transparent.
$ gradle packageDebug --stacktrace error: top-left corner pixel must be either opaque white or transparent.
2556 0