SqlCommand.ExecuteScalar 方法

作者: 来源:ITPOW(原创) 日期:2008-6-11

执行查询,并返回查询所返回的结果集中第一行的第一列。忽略其他列或行。
返回 object 类型。

常见应用:

1、检查单个值(比如用 Count 取记录条数)时,代码比 ExecuteReader 少。

cmd.CommandText = "SELECT COUNT(*) FROM dbo.region"; 
Int32 count = (Int32) cmd.ExecuteScalar();

2、插入记录的同时取其 id 值。 

static public int AddProductCategory(string newName, string connString) 
{
Int32 newProdID = 0;
string sql = "INSERT INTO Production.ProductCategory (Name) VALUES (@Name); " +
"SELECT CAST(scope_identity() AS int)";
using (SqlConnection conn = new SqlConnection(connString))
{
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.Add("@Name", SqlDbType.VarChar);
cmd.Parameters["@name"].Value = newName;
try
{
conn.Open();
newProdID = (Int32)cmd.ExecuteScalar();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
return (int)newProdID;
}
相关文章