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())
...

一行行取出。

相关推荐
棉晗榜3 小时前
无法解析位于...\global.json 的 global.json 中指定的 .NET SDK 版本
.net
时光追逐者5 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 62 期(2025年11.17-11.23)
c#·.net·.netcore
宝桥南山9 小时前
.NET 10 - Blazor web assembly应用的一些诊断方式
microsoft·微软·c#·asp.net·.net·.netcore
sz老兄闯9 小时前
对 .NET FileSystemWatcher引发内存碎片化的 反思
.net
FuckPatience12 小时前
.netcoreapp2.0与.Net Core是什么关系
c#·.net·.netcore
小码编匠13 小时前
.NET 免费开源的 Word 处理神器
后端·c#·.net
唐青枫16 小时前
一文理解 C#.NET Tuples:从基础到高级应用
c#·.net
百***58841 天前
深入浅出 SQLSugar:快速掌握高效 .NET ORM 框架
.net