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

一行行取出。

相关推荐
helloworddm15 小时前
Orleans Grain Directory 详细解析
.net
Aevget19 小时前
.NET跨平台开发工具Rider v2025.3发布——支持.NET 10
ide·.net·开发工具·rider·rider v2025.3
缺点内向20 小时前
如何在 C# 中创建、读取和更新 Excel 文档
c#·.net·excel
用户44884667106021 小时前
.NET进阶——深入理解委托(4)事件实战
c#·.net
靓仔建21 小时前
在.NET Framework 4.7.2 使用Microsoft.Practices.EnterpriseLibrary.Data配置出错
c#·.net
极客智造1 天前
深入解析.NET 中的 XDocument:解锁 XML 处理的高级特性
xml·.net
ITMr.罗2 天前
深入理解EF Core更新机制(开发中因为省事遇到的问题)
服务器·数据库·c#·.net
用户4488466710602 天前
.NET进阶——深入理解委托(3)事件入门
c#·.net
总有刁民想爱朕ha2 天前
.NET 8 和 .NET 6 性能对比的测试
.net·性能测试·.net6·.net8
总有刁民想爱朕ha2 天前
银河麒麟v10服务器版Docker部署.NET 8 WebAPI教程
docker·容器·.net·银河麒麟v10服务器版