c# – 尝试使用ExecuteScalar,并获得“指定的强制转换无效”错误

我试图通过使用产品名称来获得产品价格.以下是我正在使用的功能.
public int GetProductPrice(string ProductName)
{
    cnn.open();
    sqlCommand cmd = new sqlCommand("SELECT ProductPrice FROM Products WHERE ProductName ='" + ProductName + "'",cnn);
    int price = (int)cmd.ExecuteScalar();
    return price;
}

现在我一直得到这个错误指定的强制转换是无效的,我不知道为什么.有人能帮我吗 ?

解决方法

首先,您应该使用参数化sql而不是将参数直接放入sql中.此外,您应该使用using语句在完成后关闭命令 – 和连接.哦,并为每个操作创建一个新的sqlConnection.所以类似于:
public int GetProductPrice(string productName)
{
    // Quite possibly extract the connection creation into a separate method
    // to call here.
    using (var conn = new sqlConnection(...))
    {
        conn.open();
        using (var command = new sqlCommand(
            "SELECT ProductPrice FROM Products WHERE ProductName = @ProductName",conn))
        {
            command.AddParameter("@ProductName",sqlDbType.VarChar)
                   .Value = productName;
            object price = command.ExecuteScalar();
            // And you'd do the casting here
        }
    }
}

接下来,我们不知道ProductPrice字段的类型.可能是你得到了很长的回报,或者可能是小数.最简单的方法是使用:

object tmp = cmd.ExecuteScalar();

…然后查看调试器.还要看一下数据库中字段的类型 – 这应该真正告诉你期待什么.看看这两者之间的映射的SqlDbType枚举.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...