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

一行行取出。

相关推荐
步步为营DotNet3 小时前
深度探索.NET 中ValueTask:优化异步性能的轻量级利器
java·spring·.net
潇潇云起3 小时前
mapdb
java·开发语言·数据结构·db
喵叔哟20 小时前
8.健康检查与监控
架构·.net
bjzhang751 天前
ZR.Admin——基于.Net8 + vue2.x前后端分离的.net快速开发框架
.net·.net快速开发框架·zr.admin
喵叔哟1 天前
17.核心服务实现(上)
后端·.net
yngsqq1 天前
使用VS(.NET MAUI)开发第一个安卓APP
android·.net
追逐时光者2 天前
TIOBE 公布 C# 是 2025 年度编程语言
后端·.net
ServBay2 天前
C# 成为 2025 年的编程语言,7个C#技巧助力开发效率
后端·c#·.net
獨枭2 天前
.NET Framework 依赖版本冲突解决方案:从现象到本质
.net
云草桑2 天前
.net AI API应用 客户发的信息提取对接上下游系统报价
ai·c#·.net·semantickernel·sk