• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C#将DataTable按固定个数拆分成多个表

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

项目中出现数据量特别大的DataTable,做循环处理时比较慢,

需要将DataTable拆分成多个做多线程处理。

将DataTable拆分成多个加到DataSet里,用的时候遍历DataSet就可以了

拆分的方法如下:

        /// <summary>
        /// 分解数据表
        /// </summary>
        /// <param name="orgTable">需要分解的表</param>
        /// <param name="rowsNum">每个表包含的数据量</param>
        /// <returns></returns>
        public static DataSet SplitDataTable(DataTable orgTable, int rowsNum)
        {
            var ds = new DataSet();
            if (rowsNum <= 0 || orgTable.Rows.Count <= 0)
            {
                ds.Tables.Add(orgTable);
                return ds;
            }
            var tableNum = Convert.ToInt32(Math.Ceiling(orgTable.Rows.Count * 1.0 / rowsNum));
            var remainder = orgTable.Rows.Count % rowsNum;
            if (tableNum == 1)
            {
                ds.Tables.Add(orgTable);
            }
            else
            {
                for (var i = 0; i < tableNum; i++)
                {
                    var table = orgTable.Clone();
                    int num;
                    if (i != tableNum - 1)
                        num = rowsNum;
                    else
                        num = remainder > 0 ? remainder : rowsNum;
                    for (var j = 0; j < num; j++)
                    {
                        var row = orgTable.Rows[i * rowsNum + j];
                        table.ImportRow(row);
                    }
                    ds.Tables.Add(table);
                }
            }
            return ds;
        }

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C++SDL2中SDL_Renderer使用发布时间:2022-07-13
下一篇:
c#中读取应用程序路径的方法发布时间:2022-07-13
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap