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

相关推荐
A旧城以西1 小时前
MySQL----数据库的操作
java·开发语言·数据库·sql·学习·mysql
珹洺2 小时前
C++从入门到实战(十三)C++函数模板与类模板初阶讲解
开发语言·数据结构·c++·算法
LiLiYuan.2 小时前
关于Stream
java·开发语言·windows·python
可喜~可乐5 小时前
SQLite数据类型
数据库·sql·sqlite·c#
hongyanwin6 小时前
cmake qt 项目编译(win)
开发语言·qt
元亓亓亓7 小时前
Java后端开发day42--IO流(二)--字符集&字符流
java·开发语言
JANYI20188 小时前
在c++中老是碰到string&,这是什么意思?
开发语言·c++
冰茶_8 小时前
WPF之面板特性
microsoft·微软·c#·wpf·布局系统
passionSnail9 小时前
《MATLAB实战训练营:从入门到工业级应用》趣味入门篇-用声音合成玩音乐:MATLAB电子琴制作(超级趣味实践版)
开发语言·matlab
shenyan~9 小时前
关于Python:9. 深入理解Python运行机制
开发语言·python