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

一行行取出。

相关推荐
123的故事2 小时前
工具分享(2)-NSmartProxy内网穿透工具。
c#·.net·nsmartproxy
SEO-狼术4 小时前
Bring Agentic AI to RAD Studio
.net
足球中国5 小时前
.net winform 仿excel控件 开源地址 https://github.com/yufb12/dataexcel_winform
.net
周杰伦fans5 小时前
深入浅出AutoCAD .NET二次开发:HostApplicationServices完全解析
数据库·.net
caimouse5 小时前
Godot 4.7 内嵌 C# 模块切换到 .NET 9.0 编译指南
c#·.net·godot
rockey62715 小时前
基于AScript的SQL脚本语言发布啦!
sql·c#·.net·script·expression·动态脚本
喵叔哟1 天前
14【.NET10 实战--孢子记账--产品智能化】--智能生成预算
大数据·人工智能·.net
mincau1 天前
.NET 反编译代码语义化还原:三工具协同实战
.net·反编译·ai辅助
调试优选官2 天前
2026GEO优化工具软件技术路径拆解:从监测机制到工程落地
.net·软件开发·技术分享·geo
步步为营DotNet2 天前
.NET Aspire 在云原生微服务架构中的深度实践与剖析
云原生·架构·.net