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

一行行取出。

相关推荐
一个帅气昵称啊2 天前
.Net使用AgentFramework进行多Agent工作流编排-智能体AI开发
c#·.net·agentframework
weixin_421585012 天前
vxm.networks.Unet
python·深度学习·.net
专注VB编程开发20年2 天前
.NET 10 AOT编绎成DLL调用方式-Activex dll/标准DLL
windows·.net·aot·.net加密
罗马苏丹默罕默德2 天前
用.Net的HttpClient调用WebServices的接口
.net
用户4488466710602 天前
.NET进阶——深入理解反射(2)细说Type类型与实例创建
.net
小码编匠2 天前
C# 实现网络文件传输:打造稳定可靠的工业级工具
后端·c#·.net
关关长语3 天前
基于NCrontab实现Covarel扩展秒级任务调度
c#·.net
MoFe13 天前
【.net/.net core】【报错处理】另一个 SqlParameterCollection 中已包含 SqlParameter。
java·.net·.netcore
缺点内向3 天前
如何在C#中添加Excel文档属性?
开发语言·数据库·c#·.net·excel
2401_853448233 天前
K210环境搭建(VsCode)
vscode·踩坑·k210环境搭建