DataTable.Load(reader)注意事项

对于在C#中操作数据库查询,这样的代码很常见:

csharp 复制代码
using var cmd = ExecuteCommand(sql);
using var reader = cmd.ExecuteReader();
DataTable dt = new DataTable();
dt.Load(reader);
...

一般的查询是没问题的,但是如果涉及主键列的查询,这个时候得注意了,如果select 字段有主键字段,并且主键列会存在多行相同值,如:

这时执行完Load你会发现dt只有1行...

解决办法就是不要使用Load,而是使用

csharp 复制代码
while(reader.Read())
...

一行行取出。

相关推荐
黑夜中的潜行者2 小时前
构建高性能 WPF 大图浏览器:TiledViewer 技术解密
性能优化·c#·.net·wpf·图形渲染
初九之潜龙勿用5 小时前
C#实现导出Word图表通用方法之散点图
开发语言·c#·word·.net·office·图表
明月看潮生6 小时前
编程与数学 03-008 《看潮企业管理软件》项目开发 01 需求分析 3-1
c#·.net·需求分析·erp·企业开发·项目实践·编程与数学
步步为营DotNet7 小时前
深度钻研.NET 中Task.Run:异步任务执行的便捷入口
java·服务器·.net
云草桑7 小时前
在C# .net中RabbitMQ的核心类型和属性,除了交换机,队列关键的类型 / 属性,影响其行为
c#·rabbitmq·.net·队列
jackletter18 小时前
3dsmax2026插件开发入门:使用.net8开发
.net·3dmax·入门·插件·.net8·3dsmax2026
1314lay_10071 天前
.NET 7.0在.NET Core Web API中实现限流
.net·.netcore
步步为营DotNet1 天前
深入探究.NET中Stream:灵活高效的数据流处理核心
服务器·数据库·.net
1314lay_10071 天前
C# .Net 7.0 Core添加日志可视化
visualstudio·c#·.net·.netcore
时光追逐者1 天前
C#/.NET/.NET Core技术前沿周刊 | 第 66 期(2026年1.12-1.18)
c#·.net·.netcore