加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用C#指定的强制转换无效错误

发布时间:2020-12-16 01:53:06 所属栏目:百科 来源:网络整理
导读:我试图将一个select语句结果存储在C#变量中,但是收到此错误 “Specified cast is not valid” 当我运行它.我不知道如何解决它,请帮忙 SqlConnection con1 = new SqlConnection(ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionStri
我试图将一个select语句结果存储在C#变量中,但是收到此错误

“Specified cast is not valid”

当我运行它.我不知道如何解决它,请帮忙

SqlConnection con1 = new SqlConnection(ConfigurationManager.ConnectionStrings["MyConnectionString"].ConnectionString);

        SqlCommand cmd1 = new SqlCommand("select cast(round(sum(CAST(AvgNumbers AS numeric(12,2))),2) as decimal(12,2)) AS [Average Days] from MainTable ",con1);

        cmd1.Connection = con1;
        con1.Open();
        Int32 result = (Int32)cmd1.ExecuteScalar();
        con1.Close();

解决方法

cmd1.ExecuteScalar()未返回盒装整数.将它分配给一个对象并在调试器中查看它以查看它到底是什么.

我猜它会返回一个Decimal或一个double,你需要这样做:

Int32 result = (Int32)(double)cmd1.ExecuteScalar();

要么:

Int32 result = (Int32)(Decimal)cmd1.ExecuteScalar();

[编辑回复下面提交的问题]

要保持小数值,只需执行以下操作:

Decimal result = (Decimal) cmd1.ExecuteScalar();

如果需要,可以将小数转换为double:

double result = (double)(Decimal) cmd1.ExectuteScalar();

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读