詳解使用C#編寫(xiě)SqlHelper類
無(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類,然后創(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è)查詢操作,返回查詢結(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)我們查詢的數(shù)據(jù)不知道是什么類型的時(shí)候可以使用該類。
4.在封裝個(gè)常用的查詢方法,返回一個(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ō)明:如上。
該方法主要用于一些查詢數(shù)據(jù),dt將被填充查詢出來(lái)的數(shù)據(jù),然后返回?cái)?shù)據(jù)。
5.最后在寫(xiě)封裝一個(gè)查詢方法,該方法返回的是一個(gè)SqlDataReader類型
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 類型對(duì)象需要一直使用SqlConnection對(duì)象,所以不能釋放。該類型讀取數(shù)據(jù)是一行一行的讀取。讀取使用的是該類的Read()方法,返回值為bool判斷數(shù)據(jù)是否為空(也就是是否讀取到最后一行),該方法將自動(dòng)讀取下到下一條記錄。
作為一個(gè)初學(xué)者,本次只是簡(jiǎn)單的介紹,并復(fù)習(xí)了一下SqlHepler類。
附上全部代碼:
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,返回查詢結(jié)果中的第一行第一列的值
/// </summary>
/// <param name="sqlText">執(zhí)行的sql腳本</param>
/// <param name="parameters">參數(shù)集合</param>
/// <returns>查詢結(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í)有所幫助,也希望大家多多支持我們。
欄 目:C#教程
下一篇:C#設(shè)計(jì)模式之Facade外觀模式解決天河城購(gòu)物問(wèn)題示例
本文標(biāo)題:詳解使用C#編寫(xiě)SqlHelper類
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/5480.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實(shí)現(xiàn)手動(dòng)對(duì)資源的釋放
- 01-10C#3.0使用EventLog類寫(xiě)Windows事件日志的方法
- 01-10C#使用windows服務(wù)開(kāi)啟應(yīng)用程序的方法
- 01-10c# ArrayList的使用方法小總結(jié)
- 01-10C#使用ADO.Net部件來(lái)訪問(wèn)Access數(shù)據(jù)庫(kù)的方法
- 01-10C#使用Mutex簡(jiǎn)單實(shí)現(xiàn)程序單實(shí)例運(yùn)行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#中Socket通信用法實(shí)例詳解
- 01-10C#裝箱和拆箱原理詳解
- 01-10C#類的多態(tài)性詳解


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫(xiě)Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 04-02jquery與jsp,用jquery
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文


