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

一行行取出。

相关推荐
@LetsTGBot搜索引擎机器人3 小时前
打造属于你的 Telegram 中文版:汉化方案 + @letstgbot 搜索引擎整合教程
开发语言·python·搜索引擎·机器人·.net
我是唐青枫3 小时前
C#.NET Cronos 实战:优雅解析与执行 Cron 表达式
c#·.net
月光双刀5 小时前
给旧版 .NET 也开一扇“私有之门”——ILAccess.Fody 实现原理与设计
c#·.net·fody·il·mono.cecil
sky-stars9 小时前
.NET 任务 Task、Task.Run()、 Task.WhenAll()、Task.WhenAny()
数据库·php·.net
Crazy Struggle9 小时前
一行代码快速开发 AntdUI 风格的 WinForm 通用后台框架
.net·winform·antdui
或与且与或非19 小时前
.net 8压榨rabbitMq性能
rabbitmq·.net·ruby
唐青枫1 天前
C#.NET Cronos 实战:优雅解析与执行 Cron 表达式
c#·.net
我是唐青枫1 天前
C#.NET PeriodicTimer 深入解析:高效异步定时器的正确打开方式
c#·.net
咕白m6251 天前
如何用 C# 将 Excel 文件转换为 HTML 格式?
c#·.net
切糕师学AI2 天前
.NET 对象转Json的方式
json·.net