首页 > 代码库 > Oracle数据库“Specified cast is农田valid”
Oracle数据库“Specified cast is农田valid”
这种错误是笔者在执行一条计算符合条件的行有多少个,用OracleDataReader读取计算出的行数时发生。
查询语句为:
Select Count(1) FROM HP_TS Where TS_ID>0
C#执行过程为:
public static int GetSingle(string strSQL) { try { OpenConnection(); OracleDataReader oraDataReader = ExecuteReader(Connection, CommandType.Text, strSQL, null); int count = -1;
if (oraDataReader.HasRows == true && oraDataReader.Read()) { count = oraDataReader.GetInt32(0); // ① 此处抛出该错误异常 }
oraDataReader.Close(); return count; } catch (System.Exception ex) { throw ex; } }
后来经过调试发现是由于oraDataReader[0] (或者是oraDataReader["Count(1)"]),的类型是decimal的,所以直接用以上代码①处的结果,将发生本文所述的异常。
后来,给出如下解决方法:
将①处替换为下面所示代码
count = Convert.ToInt32(oraDataReader[0].ToString());
Oracle数据库“Specified cast is农田valid”
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。