好的,我已经创建了一个产品表ID、itemCode、一个销售表和一个返回库存项之和的视图。问题是,如果该物品尚未出售,在视图中没有它的记录。我需要检查是否有存货,以便完成进一步的销售等。
我所做的是:
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无关。
问题似乎就在眼前:
object obj = com.ExecuteScalar(); 我也试过
"SELECT COUNT(total) FROM [stock] WHERE ([itemCode] = " + TextBoxCode.Text + ")";结果是一样的。我不能让它起作用。
发布于 2011-03-21 14:12:54
试着像这样写你的if条件
if ((obj == null) || (obj == DBNull.Value)) https://stackoverflow.com/questions/5378673
复制相似问题