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

一行行取出。

相关推荐
ceclar1232 小时前
C# 的任务并行库(TPL)
开发语言·c#·.net
ceclar1234 小时前
C#异步编程async与await
c#·.net
步步为营DotNet6 小时前
借助 C# 14 特性强化 .NET 后端数据验证的深度实践
java·c#·.net
ceclar12310 小时前
C#字节流与字符流
算法·c#·.net
苏克贝塔1 天前
.NET 开发之“宿主(Host)”
.net
robot_???1 天前
Visual studio2022:找不到指定的SDK“Microsoft.NET.Sdk”
microsoft·.net·visual studio
云草桑2 天前
.NET10+AI 架构师全套实战学习文档(含源码、案例、面试题、项目源码)
人工智能·学习·ai·.net
小满Autumn2 天前
固高GTS运动控制卡 — C#开发完全指南
c#·.net·上位机·运动控制卡
云草桑2 天前
跨境信息系统术语研究 —— 产品、单据、身份名片的中文译法演变历程
面试·.net·odoo·erp·跨境