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

一行行取出。

相关推荐
我是唐青枫6 小时前
C#.NET Memory 深入解析:跨异步边界的内存视图与高性能实战
开发语言·c#·.net
light blue bird11 小时前
MES/ERP报表大致化元素组排类查询
jvm·数据库·.net·ai大数据
喵叔哟12 小时前
8. 【Blazor全栈开发实战指南】--路由与导航
数据库·微服务·.net
武藤一雄1 天前
C# 引用传递:深度解析 ref 与 out
windows·microsoft·c#·.net·.netcore
Aevget1 天前
界面控件DevExpress WinForms中文教程:Data Grid - 数据绑定(二)
.net·界面控件·winform·devexpress·ui开发
码农刚子1 天前
.NET 权限系统(RBAC)怎么设计?直接可复用
后端·.net
喵叔哟1 天前
4. 【Blazor全栈开发实战指南】--Blazor开发环境搭建
微服务·.net
csdn_aspnet1 天前
使用 C# 和 Microsoft Agent Framework 构建 AI 代理
人工智能·microsoft·ai·c#·.net·agent·ai agent
SEO_juper1 天前
XML Sitemap 详解:作用、意义与创建必要性
xml·.net·seo·数字营销·2026