c#OdbcDataReader的数据读取

先有如下c#示例代码:

string strconnect = "DSN=custom;UID=sa;PWD=123456;"

OdbcConnection odbc = new OdbcConnection(strconnect);

odbc.Open();

if (odbc.State != System.Data.ConnectionState.Open)

{

return;

}

string strSql = "select ID from mytable";

OdbcCommand odbcCmd = new OdbcCommand(strSql, odbc);

OdbcDataReader dtReader = odbc.ExecuteReader();

// 数据库里确保mytable中是有数据的

int tableid = (int)dtReader["ID"];

以上代码有时候正常运行,有时候在最后一行会提示:

System.InvalidOperationException: '不存在此行/列的数据。'

但实际上出现上面问题崩溃时,查看dtReader是可以看到里面有数据的。然后改成索引也是一样:

int tableid = (int)dtReader[0];

有时候成功,有时候失败崩溃。

通过查看帮助说明,有大致这样的描述:如果是流,在读取时可能数据还未到达。

这个意思就是在执行完语句之后立即获取其中的数据,有可能数据流还未到达,所以这个读取就会失败,也就是"列"还不存在导致崩溃。为了解决这个问题,必需先Read()一次:

dtReader.Read();

int tableid = (int)dtReader["ID"];

添加Read()之后,问题解决。

相关推荐
o0向阳而生0o16 分钟前
71、C# Parallel.ForEach 详解
c#
BillKu43 分钟前
Vue3 + TypeScript 中 hook 优化记录
开发语言·javascript·typescript
小馒头君君1 小时前
近期GitHub热榜推荐
开发语言·windows·python·学习·github
code bean1 小时前
【设计模式】用观察者模式对比事件订阅(相机举例)
观察者模式·设计模式·c#
小猫咪怎么会有坏心思呢1 小时前
华为OD机试-最佳植树距离-二分(JAVA 2025A卷)
java·开发语言·华为od
张紫娃1 小时前
bash 命令行 |
开发语言·bash
上位机付工1 小时前
不会PLC,怎么学上位机?
c#·上位机·modbus·三菱·西门子·欧姆龙plc
山海上的风2 小时前
23种设计模式--简单工厂模式理解版
java·开发语言·简单工厂模式
永生辉皇2 小时前
JS红宝书笔记 8.3 继承
开发语言·javascript·笔记
景彡先生2 小时前
C++ 性能分析工具:Valgrind 与 perf
开发语言·c++