DataTable.Load(reader)注意事项

对于在C#中操作数据库查询,这样的代码很常见:

using var cmd = ExecuteCommand(sql);
using var reader = cmd.ExecuteReader();
DataTable dt = new DataTable();
dt.Load(reader);
...

一般的查询是没问题的,但是如果涉及主键列的查询,这个时候得注意了,如果select 字段有主键字段,并且主键列会存在多行相同值,如:
DataTable.Load(reader)注意事项_第1张图片
这时执行完Load你会发现dt只有1行…
解决办法就是不要使用Load,而是使用

while(reader.Read())
...

一行行取出。

你可能感兴趣的:(那些年遇到的坑,踩坑,.net,db)