C# 将一个DataTable分解成多个DataTable

     今天在做项目时需要将一个DataTable分解成多个DataTable分批传入函数里面,于是在网上找寻了一番,修复了  存在分表的缺陷的代码。

   分表方法:

复制代码
        /// <summary>
        /// 分解数据表
        /// </summary>
        /// <param name="originalTab">需要分解的表</param>
        /// <param name="rowsNum">每个表包含的数据量</param>
        /// <returns></returns> 
        public static DataSet SplitDataTable(DataTable originalTab, int rowsNum)
        {

            int tableNum = System.Convert.ToInt32(originalTab.Rows.Count / rowsNum); //相除取整
            int remainder = System.Convert.ToInt32(originalTab.Rows.Count % rowsNum); //相除取余数
            DataSet ds = new DataSet();
            //if one table is big enough to store, use one table
            if (tableNum == 0)
            {
                ds.Tables.Add(originalTab);
            }
            else
            {

                if (remainder > 0) //如果有余数,需要多一张表存余数
                {
                    tableNum++;
                }

                DataTable[] tableSlice = new DataTable[tableNum - 1 + 1];

                //Save orginal columns into new table
                int c = 0;
                for (c = 0; c <= (tableNum - 1); c++)
                {
                    tableSlice[c] = new DataTable();
                    foreach (DataColumn dc in originalTab.Columns)
                    {
                        tableSlice[c].Columns.Add(dc.ColumnName, dc.DataType);
                    }
                }

                //Import Rows
                int i = 0;
                if (remainder > 0)
                {
                    for (i = 0; i <= (tableNum - 1); i++)
                    {
                        //if the current table is not the last table
                        if (i != tableNum - 1)
                        {
                            int j = 0;
                            for (j = i * rowsNum; j <= (((i + 1) * rowsNum) - 1); j++)
                            {
                                tableSlice[i].ImportRow(originalTab.Rows[j]);
                            }
                        }
                        else
                        {
                            int k = 0;
                            //For k = i * rowsNum To (((i + 1) * rowsNum + remainder) - 1)
                            for (k = i * rowsNum; k <= ((i * rowsNum + remainder) - 1); k++)
                            {
                                tableSlice[i].ImportRow(originalTab.Rows[k]);
                            }
                        }
                    }
                }
                else
                {
                    for (i = 0; i <= (tableNum - 1); i++)
                    {
                        int j = 0;
                        for (j = i * rowsNum; j <= (((i + 1) * rowsNum) - 1); j++)
                        {
                            tableSlice[i].ImportRow(originalTab.Rows[j]);
                        }
                    }
                }

                //Add all tables into a dataset
                foreach (DataTable dt in tableSlice)
                {
                    ds.Tables.Add(dt);
                }
            }

            return ds; 
        }
复制代码

 

   

posted @   我本梁人  阅读(1957)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
点击右上角即可分享
微信分享提示