首页 > 数据库技术 > 详细

Oracle数据库“Specified cast is农田valid”

时间:2016-08-30 17:32:02      阅读:147      评论:0      收藏:0      [点我收藏+]

 

这种错误是笔者在执行一条计算符合条件的行有多少个,用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”

原文:http://www.cnblogs.com/arxive/p/5822668.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!