C# 将一个DataTable分解成多个DataTable
今天在做项目时需要将一个DataTable分解成多个DataTable分批传入函数里面,于是在网上找寻了一番,修复了angle_greensky110 存在分表的缺陷的代码。
分表方法:
/// <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; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 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的设计差异