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

一行行取出。

相关推荐
bugcome_com11 小时前
深入理解 C# 中 new 关键字的三重核心语义
c#·.net
我是唐青枫14 小时前
C#.NET struct 全解析:什么时候该用值类型?
开发语言·c#·.net
喵叔哟15 小时前
13.生产环境实践
.net
切糕师学AI1 天前
.NET 文件操作中常见的内存泄漏场景梳理
.net·内存泄漏
唐青枫1 天前
深入理解 C#.NET record:不可变对象与值语义的现代实践
c#·.net
追逐时光者1 天前
一个 WPF 开源、免费的 SVG 图像查看控件
后端·.net
时光追逐者2 天前
一个基于 .NET 开源、功能强大的分布式微服务开发框架
分布式·微服务·开源·c#·.net·.net core
步步为营DotNet2 天前
深入探究.NET中依赖注入(DI)的生命周期管理:构建稳健且高效的应用
.net
步步为营DotNet2 天前
深度解析.NET中LINQ查询的延迟执行与缓存机制:优化数据查询性能
缓存·.net·linq