首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
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

Stack Overflow用户

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

试着像这样写你的if条件

代码语言:javascript
运行
复制
 if ((obj == null) || (obj == DBNull.Value)) 
票数 1
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5378673

复制
相关文章

相似问题

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