Получение одного значения из базы данных
Область применения: платформа .NET Framework .NET Standard
Может возникнуть необходимость вернуть сведения из базы данных, которые представляют собой одиночное значение, а не форму таблицы или поток данных. Например, может потребоваться вернуть результат статистической функции, например COUNT(*), SUM(Price) или AVG(Quantity). Объект Command предоставляет возможность возвращать одиночные значения с помощью метода ExecuteScalar. Метод ExecuteScalar возвращает значение первого столбца первой строки результирующего набора в виде скалярного значения.
Пример
В следующем примере кода в базу данных при помощи SqlCommand вставляется новое значение. Метод ExecuteScalar используется, чтобы вернуть значение столбца идентификатора для вставленной записи.
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;
}