首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ASP .NET C# SQL在ExecuteScalar上返回DBNULL

ASP .NET C# SQL在ExecuteScalar上返回DBNULL
EN

Stack Overflow用户
提问于 2011-03-21 14:02:18
回答 3查看 6.2K关注 0票数 1

好的,我已经创建了一个产品表ID、itemCode、一个销售表和一个返回库存项之和的视图。问题是,如果该物品尚未出售,在视图中没有它的记录。我需要检查是否有存货,以便完成进一步的销售等。

我所做的是:

代码语言:javascript
运行
复制
    string selectSQL = "SELECT [total] FROM [stock] WHERE ([itemCode] = " + TextBoxCode.Text + ")";
    SqlConnection con = new SqlConnection(connectionString);
    SqlCommand com = new SqlCommand(selectSQL, con);
    try
    {
        con.Open();          
        object obj = com.ExecuteScalar();

        if (obj == null) //(also tried is DBNull)
        {
            lblStatus.Text = "Does not exist in stock";
        }
        else
        {
            sum = com.ExecuteScalar().ToString();
            lblStatus.Text = "Items in stock: " + sum;
        }
    }
    catch (Exception err)
    {
        lblStatus.Text = err.Message;
    }
    finally
    {
        con.Close();
    }

当项目实际存在于库存中时,它可以正常工作,但是如果没有记录,则会得到错误:

将nvarchar值'1E001‘转换为数据类型int时,

转换失败。

'1E001‘是我的股票视图中的第一个itemCode,但它与我试图插入的itemCode无关。

问题似乎就在眼前:

代码语言:javascript
运行
复制
object obj = com.ExecuteScalar(); 

我也试过

代码语言:javascript
运行
复制
"SELECT COUNT(total) FROM [stock] WHERE ([itemCode] = " + TextBoxCode.Text + ")";

结果是一样的。我不能让它起作用。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-03-21 14:14:09

如果ItemCode不是一个数字,那么您需要在插入TextBoxCode.Text的代码之前和之后包含单引号。示例:

代码语言:javascript
运行
复制
string selectSQL = "SELECT [total] FROM [stock] WHERE ([itemCode] = '" + TextBoxCode.Text + "')";

警告:使用此代码将为SQL注入攻击留出很大的空间!

使用参数的首选方法是:

代码语言:javascript
运行
复制
string selectSQL = "SELECT [total] FROM [stock] WHERE ([itemCode] = @ItemCode)";
SqlCommand com = new SqlCommand(selectSQL, con);
com.Parameters.AddWithValue("@ItemCode", TextBoxCode.Text);

对于您的问题本身,如果结果集中没有行,ExecuteScalar的结果将为null (一个.NET null条件)。如果结果集的第一行的第一个字段是数据库Null值(DBNull.Value),则这是不同的。

若要检查两者,请使用:

代码语言:javascript
运行
复制
if (obj == null || obj == DBNull.Value) 

注意:您不应该第二次使用ExecuteScalar (如果它不是null),因为您已经在obj变量中得到了结果。

票数 8
EN

Stack Overflow用户

发布于 2011-03-21 14:12:54

试着像这样写你的if条件

代码语言:javascript
运行
复制
 if ((obj == null) || (obj == DBNull.Value)) 
票数 1
EN

Stack Overflow用户

发布于 2011-03-21 14:12:32

看起来,文本周围需要单引号,如下所示:

代码语言:javascript
运行
复制
"SELECT COUNT(total) FROM [stock] WHERE ([itemCode] = '" + TextBoxCode.Text + "')";
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5378673

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档