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

项目中出现数据量特别大的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;
        }
复制代码

 

posted @   新*  阅读(1445)  评论(1编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)

喜欢请打赏

扫描二维码打赏

支付宝打赏

点击右上角即可分享
微信分享提示