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

一行行取出。

相关推荐
wangl_9215 小时前
初探 C# 15 的 Union Types
java·开发语言·算法·c#·.net·.net core
SEO-狼术15 小时前
Make Range Input Simpler
pdf·.net
wangl_9218 小时前
C# / .NET 在工业环境中的优势
开发语言·c#·.net·.netcore·.net core·visual studio
△曉風殘月〆18 小时前
不同.NET版本中的WPF新增功能
.net·wpf
余衫马18 小时前
Microsoft Semantic Kernel 入门指南
人工智能·microsoft·.net·agent·智能体
码农学院2 天前
itextsharp .net中如何设置两个表格的间距设为0,取网站的域名,协议、端口、当前站点目录的地址
开发语言·c#·.net
步步为营DotNet2 天前
深挖.NET 11:.NET Aspire 引领云原生开发新高度
云原生·.net
Java面试题总结2 天前
如何更好的创建skill
.net
The Shio3 天前
OptiByte 操练场:面向 IoT/嵌入式的协议可视化调试工具
网络·嵌入式硬件·物联网·c#·.net·业界资讯·iot