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

一行行取出。

相关推荐
fdc201711 小时前
解耦的艺术:用责任链模式构建可插拔的文件处理流水线
c#·.net·责任链模式
小码编匠12 小时前
WPF 如何在 MVVM模式下实现 DataGrid编辑功能
后端·c#·.net
dLNbrcWzV1 天前
迈达斯桥梁建模与分析:探索多样桥梁结构的奥秘
.net
大黄说说2 天前
.NET 10 Minimal APIs 主要应用场景全景指南:从原型到企业级生产
.net
专注VB编程开发20年2 天前
c# vb.net Redis 左侧添加,右侧添加(添加到头部,添加到尾部)
redis·c#·.net
专注VB编程开发20年3 天前
c#,vb.net Redis vs ODBC/ADO 查库的速度差距,写入json数据和字典数据
redis·c#·.net
大鹏说大话3 天前
基于.NET和C#构建光伏IoT物模型方案:架构设计与实践指南
物联网·c#·.net
专注VB编程开发20年3 天前
流式解压 + 分块处理 + 增量安装
.net
guizhoumen4 天前
liunx环境手动安装.net8的教程
.net
全栈小55 天前
【C#】.net 6.0和8.0有什么区别,以及8.0增加了那些功能,这些功能有那些作用
开发语言·c#·.net