返回單值的ADO.NET數(shù)據(jù)庫信息案例分析
ADO.NET還是比較常用的,于是我研究了一下ADO.NET數(shù)據(jù)庫,在這里拿出來和大家分享一下,希望對(duì)大家有用。您可能需要返回只是單個(gè)值的ADO.NET數(shù)據(jù)庫信息,而不需要返回表或數(shù)據(jù)流形式的ADO.NET數(shù)據(jù)庫信息。
#T#例如,可能需要返回 COUNT(*)、SUM(Price) 或 AVG(Quantity) 等聚合函數(shù)的結(jié)果。 Command 對(duì)象使用 ExecuteScalar 方法提供了返回單個(gè)值的功能。 ExecuteScalar 方法以標(biāo)量值的形式返回結(jié)果集第一行的第一列的值。下面的代碼示例使用 SqlCommand 在數(shù)據(jù)庫中插入一個(gè)新值。 使用 ExecuteScalar 方法可返回已插入記錄的標(biāo)識(shí)列值。
- 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
C#
- 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;
- }