Uzyskiwanie pojedynczej wartości z bazy danych
Może być konieczne zwrócenie informacji o bazie danych, które są po prostu pojedynczą wartością, a nie w postaci tabeli lub strumienia danych. Na przykład możesz zwrócić wynik funkcji agregującej, takiej jak COUNT(*), SUM(Price) lub AVG(Quantity). Obiekt Command zapewnia możliwość zwracania pojedynczych wartości przy użyciu metody ExecuteScalar . Metoda ExecuteScalar zwraca wartość jako wartość skalarną pierwszej kolumny pierwszego wiersza zestawu wyników.
Poniższy przykład kodu wstawia nową wartość w bazie danych przy użyciu elementu SqlCommand. Metoda ExecuteScalar służy do zwracania wartości kolumny tożsamości dla wstawionego rekordu.
public static int AddProductCategory(string newName, string connString)
{
var newProdID = 0;
const string sql =
"INSERT INTO Production.ProductCategory (Name) VALUES (@Name); "
+ "SELECT CAST(scope_identity() AS int)";
using (SqlConnection conn = new(connString))
{
SqlCommand cmd = new(sql, conn);
cmd.Parameters.Add("@Name", SqlDbType.VarChar);
cmd.Parameters["@name"].Value = newName;
try
{
conn.Open();
newProdID = (int)cmd.ExecuteScalar();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
return newProdID;
}
Public Function AddProductCategory( _
ByVal newName As String, ByVal connString As String) As Integer
Dim newProdID As Int32 = 0
Dim sql As String = _
"INSERT INTO Production.ProductCategory (Name) VALUES (@Name); " _
& "SELECT CAST(scope_identity() AS int);"
Using conn As New SqlConnection(connString)
Dim cmd As New SqlCommand(sql, conn)
cmd.Parameters.Add("@Name", SqlDbType.VarChar)
cmd.Parameters("@Name").Value = newName
Try
conn.Open()
newProdID = Convert.ToInt32(cmd.ExecuteScalar())
Catch ex As Exception
Console.WriteLine(ex.Message)
End Try
End Using
Return newProdID
End Function