日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[转]ExecuteNonQuery()、ExecuteReader()、ExecuteScalar()的简单说明

發布時間:2025/4/16 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [转]ExecuteNonQuery()、ExecuteReader()、ExecuteScalar()的简单说明 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

http://blog.csdn.net/wuyujie1219/archive/2009/07/26/4380956.aspx

??? 在連接SQL Server數據庫:首先創建SqlConnection類和SqlCommand類實例分別用于連接到SQL Server數據庫和執行SQL語句命令,然后打開數據連接并使用SqlCommand的相應方法執行SQL語句。
ExecuteNonQuery()方法執行SQL語句并且不返回數據;
ExecuteReader()方法將SQL語句發送給SqlConnection并生產一個SqlDataReader類對象,該SqlDataReader對象包含SQL命令返回的數據;
ExecuteScalar()方法執行SQl查詢,并返回查詢結果集中的第一行的第一列,忽略額外的列或行!

?例如:
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 對象使用,執行得到的數據集為只讀且光標只能從前向后移動。

????????????

string oSql = "select id, password, name, level from verify";
SqlCommand comm = new SqlCommand(oSql, con);
con.Open();//在調用方法前打開數據庫連接,可以減少數據庫連接所花的時間,節省數據庫資源。
SqlDataReader dr = comm.ExecuteReader ();
While(dr.Read())
{
String id = "";
id = dr[0].ToString(); //(0為第一列)
//或 id=dr["id"].ToString();(引用字段名)
//或id= dr.GetString (dr.GetOrdinal ("id"));
}
//在讀取數據結束后才能關閉數據庫,因為 SqlDataReader 對象的數據源必須保持數據庫連接。
con.Close();

?


本文轉自火地晉博客園博客,原文鏈接:http://www.cnblogs.com/yelaiju/archive/2010/10/21/1857863.html,如需轉載請自行聯系原作者

總結

以上是生活随笔為你收集整理的[转]ExecuteNonQuery()、ExecuteReader()、ExecuteScalar()的简单说明的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。