[转]ExecuteNonQuery()、ExecuteReader()、ExecuteScalar()的简单说明
http://blog.csdn.net/wuyujie1219/archive/2009/07/26/4380956.aspx
??? 在連接SQL Server數(shù)據(jù)庫(kù):首先創(chuàng)建SqlConnection類和SqlCommand類實(shí)例分別用于連接到SQL Server數(shù)據(jù)庫(kù)和執(zhí)行SQL語(yǔ)句命令,然后打開數(shù)據(jù)連接并使用SqlCommand的相應(yīng)方法執(zhí)行SQL語(yǔ)句。
ExecuteNonQuery()方法執(zhí)行SQL語(yǔ)句并且不返回?cái)?shù)據(jù);
ExecuteReader()方法將SQL語(yǔ)句發(fā)送給SqlConnection并生產(chǎn)一個(gè)SqlDataReader類對(duì)象,該SqlDataReader對(duì)象包含SQL命令返回的數(shù)據(jù);
ExecuteScalar()方法執(zhí)行SQl查詢,并返回查詢結(jié)果集中的第一行的第一列,忽略額外的列或行!
?例如:
SqlConnection MyConncetion = new SqlConnection(m_SqlConnection);
SqlCommand MyCmd = new SqlCommand(p_StrSql, MyConncetion);
一:
MyConncetion.Open();
MyCmd.ExecuteNonQuery();
二:
?MyConncetion.Open();
?SqlDataReader MyReader = MyCmd.ExecuteReader();
??????????? if (MyReader.Read())
??????????? {
??????????????? return 0;
??????????? }
??????????? else
??????????? {
??????????????? throw new Exception("Value Unavailable!");
??????????? }
三:
MyConnection.Open();
SqlDataAdapter SqlDa = new SqlDataAdapter(p_StrSql, MyConnection);
DataSet Ds = new DataSet("ds");
SqlDa.Fill(Ds);
四:
MyConncetion.Open();
object r = MyCmd.ExecuteScalar();
??????????? if (object.Equals(r, null))
??????????? {
??????????????? throw new Exception("Value Unavailable!");
??????????? }
??????????? else
??????????? {
??????????????? return (int)r;
??????????? }
注意:ExecuteReader() 方法需要配合 SqlDataReader 對(duì)象使用,執(zhí)行得到的數(shù)據(jù)集為只讀且光標(biāo)只能從前向后移動(dòng)。
????????????
string oSql = "select id, password, name, level from verify";SqlCommand comm = new SqlCommand(oSql, con);
con.Open();//在調(diào)用方法前打開數(shù)據(jù)庫(kù)連接,可以減少數(shù)據(jù)庫(kù)連接所花的時(shí)間,節(jié)省數(shù)據(jù)庫(kù)資源。
SqlDataReader dr = comm.ExecuteReader ();
While(dr.Read())
{
String id = "";
id = dr[0].ToString(); //(0為第一列)
//或 id=dr["id"].ToString();(引用字段名)
//或id= dr.GetString (dr.GetOrdinal ("id"));
}
//在讀取數(shù)據(jù)結(jié)束后才能關(guān)閉數(shù)據(jù)庫(kù),因?yàn)?SqlDataReader 對(duì)象的數(shù)據(jù)源必須保持?jǐn)?shù)據(jù)庫(kù)連接。
con.Close();
?
本文轉(zhuǎn)自火地晉博客園博客,原文鏈接:http://www.cnblogs.com/yelaiju/archive/2010/10/21/1857863.html,如需轉(zhuǎn)載請(qǐng)自行聯(lián)系原作者
總結(jié)
以上是生活随笔為你收集整理的[转]ExecuteNonQuery()、ExecuteReader()、ExecuteScalar()的简单说明的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: ubuntu下的win交叉编译
- 下一篇: [Firebug]用来武装Firebug