다음을 통해 공유


데이터베이스에서 단일 값 가져오기(ADO.NET)

테이블이나 데이터 스트림 형식보다는 단순히 단일 값인 데이터베이스 정보를 반환해야 하는 경우가 있습니다. 예를 들어, COUNT(*), SUM(Price) 또는 AVG(Quantity)와 같은 집계 함수의 결과를 반환하려는 경우입니다. Command 개체에서는 ExecuteScalar 메서드를 사용하여 단일 값을 반환할 수 있습니다. ExecuteScalar 메서드는 결과 집합에서 첫째 행의 첫째 열 값을 스칼라 값으로 반환합니다.

다음 코드 예제에서는 SqlCommand를 사용하여 데이터베이스에 새 값을 삽입합니다. 여기서 ExecuteScalar 메서드는 삽입된 레코드의 ID 열 값을 반환하는 데 사용됩니다.

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

참고 항목

개념

명령 실행(ADO.NET)

DbConnection, DbCommand 및 DbException(ADO.NET)

기타 리소스

명령 및 매개 변수(ADO.NET)