国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > C# > 正文

詳解使用C#編寫(xiě)SqlHelper類(lèi)

2020-01-24 00:28:07
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

無(wú)聊的周末,學(xué)習(xí)、編碼無(wú)力。想找點(diǎn)事干但又不知道干點(diǎn)什么,猛然發(fā)現(xiàn)自己學(xué)過(guò)的SqlHelper快忘記了。于是乎虎軀一震心想怎能如此墮落下去,立馬打開(kāi)電腦,雙手摸上鍵盤(pán)。寫(xiě)下此文作為學(xué)習(xí)過(guò)程中的復(fù)習(xí),并分享出知識(shí)(順便打發(fā)時(shí)間-^.^-)。

下面開(kāi)始正文

這里以控制臺(tái)程序?yàn)榘咐J紫任覀冃枰扰渲靡幌逻B接字符串,我們需要在app.config文件中增加如下節(jié)點(diǎn):

<connectionStrings>   <add name="Sql" connectionString="server=數(shù)據(jù)庫(kù)地址;uid=用戶名;pwd=密碼;database=數(shù)據(jù)庫(kù)名"/>  </connectionStrings>

1.接著需要?jiǎng)?chuàng)建一個(gè)名為SqlHepler類(lèi),然后創(chuàng)建一個(gè)方法來(lái)獲取app.config文件中配置的連接字符串。

public static string GetSqlConnectionString() {   return ConfigurationManager.     ConnectionStrings["Sql"].ConnectionString; }

 2.下面來(lái)封裝第一個(gè)SqlHepler方法,封裝一個(gè)執(zhí)行的sql 返回受影響的行數(shù)。

 public static int ExecuteNonQuery(string sqlText,params SqlParameter[] parameters){   using (SqlConnection conn = new SqlConnection(GetSqlConnectionString()))     {     using (SqlCommand cmd=conn.CreateCommand())     {       conn.Open();  //打開(kāi)數(shù)據(jù)庫(kù)       cmd.CommandText = sqlText;  //對(duì)CommandText進(jìn)行賦值       cmd.Parameters.AddRange(parameters);  //對(duì)數(shù)據(jù)庫(kù)使用參數(shù)進(jìn)行賦值       return cmd.ExecuteNonQuery();     }   }}

參數(shù)說(shuō)明:sqlText:需要執(zhí)行的sql腳本,parameters:需要的參數(shù)集合

該方法主要是用于執(zhí)行,刪除、更新和插入操作,返回受影響的行數(shù)。

3.繼續(xù)封裝一個(gè)查詢(xún)操作,返回查詢(xún)結(jié)果中的第一行第一列的值

public static object ExecuteScalar(string sqlText, params SqlParameter[] parameters) {  using (SqlConnection conn=new SqlConnection(GetSqlConnectionString()))  {   using (SqlCommand cmd=conn.CreateCommand())   {     conn.Open();     cmd.CommandText = sqlText;     cmd.Parameters.AddRange(parameters);     return cmd.ExecuteScalar();   }  }}

參數(shù)說(shuō)明:如上。

該方法的返回值第object,所以當(dāng)我們查詢(xún)的數(shù)據(jù)不知道是什么類(lèi)型的時(shí)候可以使用該類(lèi)。

4.在封裝個(gè)常用的查詢(xún)方法,返回一個(gè)DataTable

public static DataTable ExecuteDataTable(string sqlText, params SqlParameter[] parameters)  {  using (SqlDataAdapter adapter =new SqlDataAdapter(sqlText,GetSqlConnectionString()))  {    DataTable dt = new DataTable();    adapter.SelectCommand.Parameters.AddRange(parameters);    adapter.Fill(dt);    return dt;   }}

參數(shù)說(shuō)明:如上。

 該方法主要用于一些查詢(xún)數(shù)據(jù),dt將被填充查詢(xún)出來(lái)的數(shù)據(jù),然后返回?cái)?shù)據(jù)。

5.最后在寫(xiě)封裝一個(gè)查詢(xún)方法,該方法返回的是一個(gè)SqlDataReader類(lèi)型

public static SqlDataReader ExecuteReader(string sqlText, params SqlParameter[] parameters){   //SqlDataReader要求,它讀取數(shù)據(jù)的時(shí)候有,它獨(dú)占它的SqlConnection對(duì)象,而且SqlConnection必須是Open狀態(tài)   SqlConnection conn = new SqlConnection(GetSqlConnectionString());//不要釋放連接,因?yàn)楹竺孢€需要連接打開(kāi)狀態(tài)   SqlCommand cmd = conn.CreateCommand();   conn.Open();   cmd.CommandText = sqlText;   cmd.Parameters.AddRange(parameters);   //CommandBehavior.CloseConnection當(dāng)SqlDataReader釋放的時(shí)候,順便把SqlConnection對(duì)象也釋放掉   return cmd.ExecuteReader(CommandBehavior.CloseConnection); }

參數(shù)說(shuō)明:依舊如上。

該方法返回的SqlDataReader 類(lèi)型對(duì)象需要一直使用SqlConnection對(duì)象,所以不能釋放。該類(lèi)型讀取數(shù)據(jù)是一行一行的讀取。讀取使用的是該類(lèi)的Read()方法,返回值為bool判斷數(shù)據(jù)是否為空(也就是是否讀取到最后一行),該方法將自動(dòng)讀取下到下一條記錄。

作為一個(gè)初學(xué)者,本次只是簡(jiǎn)單的介紹,并復(fù)習(xí)了一下SqlHepler類(lèi)。

附上全部代碼:

using System.Configuration;using System.Data;using System.Data.SqlClient;namespace UserInfoMgr{  class SqlHelper  {    /// <summary>    /// 獲取連接字符串    /// </summary>    /// <returns>連接字符串</returns>    public static string GetSqlConnectionString()    {      return ConfigurationManager.ConnectionStrings["Sql"].ConnectionString;    }    /// <summary>    /// 封裝一個(gè)執(zhí)行的sql 返回受影響的行數(shù)    /// </summary>    /// <param name="sqlText">執(zhí)行的sql腳本</param>    /// <param name="parameters">參數(shù)集合</param>    /// <returns>受影響的行數(shù)</returns>    public static int ExecuteNonQuery(string sqlText,params SqlParameter[] parameters)    {      using (SqlConnection conn = new SqlConnection(GetSqlConnectionString()))      {        using (SqlCommand cmd=conn.CreateCommand())        {          conn.Open();          cmd.CommandText = sqlText;          cmd.Parameters.AddRange(parameters);          return cmd.ExecuteNonQuery();        }      }    }    /// <summary>    /// 執(zhí)行sql,返回查詢(xún)結(jié)果中的第一行第一列的值    /// </summary>    /// <param name="sqlText">執(zhí)行的sql腳本</param>    /// <param name="parameters">參數(shù)集合</param>    /// <returns>查詢(xún)結(jié)果中的第一行第一列的值</returns>    public static object ExecuteScalar(string sqlText, params SqlParameter[] parameters)    {      using (SqlConnection conn=new SqlConnection(GetSqlConnectionString()))      {        using (SqlCommand cmd=conn.CreateCommand())        {          conn.Open();          cmd.CommandText = sqlText;          cmd.Parameters.AddRange(parameters);          return cmd.ExecuteScalar();        }      }    }    /// <summary>    /// 執(zhí)行sql 返回一個(gè)DataTable    /// </summary>    /// <param name="sqlText">執(zhí)行的sql腳本</param>    /// <param name="parameters">參數(shù)集合</param>    /// <returns>返回一個(gè)DataTable</returns>    public static DataTable ExecuteDataTable(string sqlText, params SqlParameter[] parameters)     {      using (SqlDataAdapter adapter =new SqlDataAdapter(sqlText,GetSqlConnectionString()))      {        DataTable dt = new DataTable();        adapter.SelectCommand.Parameters.AddRange(parameters);        adapter.Fill(dt);        return dt;      }    }    /// <summary>    /// 執(zhí)行sql腳本    /// </summary>    /// <param name="sqlText">執(zhí)行的sql腳本</param>    /// <param name="parameters">參數(shù)集合</param>    /// <returns>返回一個(gè)SqlDataReader</returns>    public static SqlDataReader ExecuteReader(string sqlText, params SqlParameter[] parameters)    {      //SqlDataReader要求,它讀取數(shù)據(jù)的時(shí)候有,它獨(dú)占它的SqlConnection對(duì)象,而且SqlConnection必須是Open狀態(tài)      SqlConnection conn = new SqlConnection(GetSqlConnectionString());//不要釋放連接,因?yàn)楹竺孢€需要連接打開(kāi)狀態(tài)      SqlCommand cmd = conn.CreateCommand();      conn.Open();      cmd.CommandText = sqlText;      cmd.Parameters.AddRange(parameters);      //CommandBehavior.CloseConnection當(dāng)SqlDataReader釋放的時(shí)候,順便把SqlConnection對(duì)象也釋放掉      return cmd.ExecuteReader(CommandBehavior.CloseConnection);     }  }}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 封丘县| 东方市| 慈利县| 三江| 博野县| 太原市| 略阳县| 平武县| 衡山县| 屏东市| 邵武市| 美姑县| 辽宁省| 磴口县| 农安县| 无锡市| 喀喇| 通渭县| 开平市| 庄浪县| 仁寿县| 兴安盟| 道孚县| 石林| 涞水县| 进贤县| 泾阳县| 洛浦县| 公主岭市| 屯门区| 东丽区| 渭源县| 观塘区| 鲜城| 唐山市| 华亭县| 清水河县| 若尔盖县| 陕西省| 石嘴山市| 仙居县|