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

一行行取出。

相关推荐
我是唐青枫4 小时前
C#.NET ConcurrentBag<T> 设计原理与使用场景
c#·.net
该用户已不存在8 小时前
不止是初始化,4个C# 构造函数解析与实例
后端·c#·.net
曲幽13 小时前
FastAPI数据库实战:从SQLAlchemy原理到高效连接管理,告别性能瓶颈
python·sqlite·flask·fastapi·web·sqlalchemy·db
ou.cs13 小时前
WPF TreeView 自动展开所有节点:附加行为(Attached Behavior)保姆级实现教程
c#·.net·wpf
用户2986985301414 小时前
C# Word文档页面操作:告别手动,高效掌控你的Word文档!
后端·c#·.net
鸠摩智首席音效师15 小时前
如何查看 Windows 上安装的 .NET Framework 版本 ?
windows·.net
步步为营DotNet15 小时前
深度解读.NET中ConcurrentDictionary:高效线程安全字典的原理与应用
java·安全·.net
追逐时光者1 天前
C#/.NET/.NET Core技术前沿周刊 | 第 65 期(2026年1.1-1.11)
后端·.net
步步为营DotNet2 天前
深度解析.NET 中IAsyncEnumerable:异步迭代的高效实现与应用】
服务器·数据库·.net