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

本文关键字:转换 无效 错误 使用 | 更新日期: 2023-09-27 18:00:12

我试图在C#变量中存储一个select语句结果,但得到了这个错误

"指定的强制转换无效"

当我运行它时。我不确定如何解决它。请帮助

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();

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

cmd1.ExecuteScalar()未返回带框整数。将它分配给一个对象,然后在调试器中查看它,看看它到底是什么

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

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

或者:

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

[编辑以回应以下通信中的问题]

要保留十进制值,只需执行以下操作:

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

如果需要的话,你可以将小数转换为双精度:

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

结果基本上不是Int32。你把它选为Decimal(12, 2),所以我不知道你为什么会期望它。

我的猜测是它将是doubledecimal,但如果您将调用从强制转换中分离出来并查看调试器,那么它应该是显而易见的:

object result = cmd1.ExecuteScalar();
// Now look at the type of the value of result

您的结果显然不是Int32,因此您可以使用它;

var result = cmd1.ExecuteScalar();

之后,您可以检查它是哪种类型。或者使用;

object result = cmd1.ExecuteScalar();

也许你可以投射它。记住,你可以很容易地在调试器中查看它。

您在SQL中将值强制转换为十进制,因此请尝试在c#代码中强制转换为小数。