次の方法で共有


データベースからの単一の値の取得

適用対象: .NET Framework .NET .NET Standard

ADO.NET のダウンロード

テーブルやデータ ストリームの形式ではなく、単に 1 つの値をデータベース情報として返すことが必要な場合があります。 たとえば、COUNT(*)、SUM(Price)、AVG(Quantity) などの集約関数の結果を返す場合です。 Command オブジェクトでは、ExecuteScalar メソッドを使用して単一の値を返す機能が提供されています。 ExecuteScalar メソッドでは、結果セットの 1 行目の 1 列目の値がスカラー値として返されます。

SqlCommand を使用して新しい値をデータベースに挿入するコード サンプルを次に示します。 挿入したレコードの ID 列の値を取得するために、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;
}

関連項目