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()之后,问题解决。

相关推荐
是Dream呀4 分钟前
速度与精度的结合:Faster R-CNN模型的性能剖析
开发语言·r语言·cnn
wait a minutes7 分钟前
【c++】leetcode763 划分字母区间
开发语言·c++
csdn_aspnet17 分钟前
C# 求梯形面积的程序(Program to find area of a Trapezoid)
c#
〃冷·夏ぐ28 分钟前
Java内存模型(JMM)
java·开发语言
饭碗的彼岸one42 分钟前
重生之我在10天内卷赢C++ - DAY 2
linux·开发语言·c++·笔记·算法·vim
程序员编程指南1 小时前
Qt 移动应用性能优化策略
c语言·开发语言·c++·qt·性能优化
励志成为糕手1 小时前
编程语言Java——核心技术篇(五)IO流:数据洪流中的航道设计
java·开发语言·性能优化
世界emm2 小时前
Python 脚本:获取公网 IPv4 和 IPv6 地址
开发语言·python
慕y2742 小时前
Java学习第八十四部分——HttpClient
java·开发语言·学习
LZQqqqqo2 小时前
C#_创建自己的MyList列表
java·算法·c#