Udostępnij przez


Uzyskiwanie pojedynczej wartości z bazy danych

Dotyczy: .NET Framework .NET Standard

Pobieranie ADO.NET

Może zajść potrzeba zwrócenia danych z bazy, które są pojedynczą wartością, zamiast przyjmować postać 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.

Example

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.

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;
}

Zobacz także