這篇文章將為大家詳細講解有關C#如何編寫SqlHelper類,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
這里以控制臺程序為案例。首先我們需要先配置一下連接字符串,我們需要在app.config文件中增加如下節點:
<connectionStrings> <add name="Sql" connectionString="server=數據庫地址;uid=用戶名;pwd=密碼;database=數據庫名"/> </connectionStrings>
1.接著需要創建一個名為SqlHepler類,然后創建一個方法來獲取app.config文件中配置的連接字符串。
public static string GetSqlConnectionString()
{
return ConfigurationManager.
ConnectionStrings["Sql"].ConnectionString;
}2.下面來封裝第一個SqlHepler方法,封裝一個執行的sql 返回受影響的行數。
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; //對CommandText進行賦值
cmd.Parameters.AddRange(parameters); //對數據庫使用參數進行賦值
return cmd.ExecuteNonQuery();
}
}
}參數說明:sqlText:需要執行的sql腳本,parameters:需要的參數集合
該方法主要是用于執行,刪除、更新和插入操作,返回受影響的行數。
3.繼續封裝一個查詢操作,返回查詢結果中的第一行第一列的值
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();
}
}
}參數說明:如上。
該方法的返回值第object,所以當我們查詢的數據不知道是什么類型的時候可以使用該類。
4.在封裝個常用的查詢方法,返回一個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;
}
}參數說明:如上。
該方法主要用于一些查詢數據,dt將被填充查詢出來的數據,然后返回數據。
5.最后在寫封裝一個查詢方法,該方法返回的是一個SqlDataReader類型
public static SqlDataReader ExecuteReader(string sqlText, params SqlParameter[] parameters)
{
//SqlDataReader要求,它讀取數據的時候有,它獨占它的SqlConnection對象,而且SqlConnection必須是Open狀態
SqlConnection conn = new SqlConnection(GetSqlConnectionString());//不要釋放連接,因為后面還需要連接打開狀態
SqlCommand cmd = conn.CreateCommand();
conn.Open();
cmd.CommandText = sqlText;
cmd.Parameters.AddRange(parameters);
//CommandBehavior.CloseConnection當SqlDataReader釋放的時候,順便把SqlConnection對象也釋放掉
return cmd.ExecuteReader(CommandBehavior.CloseConnection);
}參數說明:依舊如上。
該方法返回的SqlDataReader 類型對象需要一直使用SqlConnection對象,所以不能釋放。該類型讀取數據是一行一行的讀取。讀取使用的是該類的Read()方法,返回值為bool判斷數據是否為空(也就是是否讀取到最后一行),該方法將自動讀取下到下一條記錄。
作為一個初學者,本次只是簡單的介紹,并復習了一下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>
/// 封裝一個執行的sql 返回受影響的行數
/// </summary>
/// <param name="sqlText">執行的sql腳本</param>
/// <param name="parameters">參數集合</param>
/// <returns>受影響的行數</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>
/// 執行sql,返回查詢結果中的第一行第一列的值
/// </summary>
/// <param name="sqlText">執行的sql腳本</param>
/// <param name="parameters">參數集合</param>
/// <returns>查詢結果中的第一行第一列的值</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>
/// 執行sql 返回一個DataTable
/// </summary>
/// <param name="sqlText">執行的sql腳本</param>
/// <param name="parameters">參數集合</param>
/// <returns>返回一個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>
/// 執行sql腳本
/// </summary>
/// <param name="sqlText">執行的sql腳本</param>
/// <param name="parameters">參數集合</param>
/// <returns>返回一個SqlDataReader</returns>
public static SqlDataReader ExecuteReader(string sqlText, params SqlParameter[] parameters)
{
//SqlDataReader要求,它讀取數據的時候有,它獨占它的SqlConnection對象,而且SqlConnection必須是Open狀態
SqlConnection conn = new SqlConnection(GetSqlConnectionString());//不要釋放連接,因為后面還需要連接打開狀態
SqlCommand cmd = conn.CreateCommand();
conn.Open();
cmd.CommandText = sqlText;
cmd.Parameters.AddRange(parameters);
//CommandBehavior.CloseConnection當SqlDataReader釋放的時候,順便把SqlConnection對象也釋放掉
return cmd.ExecuteReader(CommandBehavior.CloseConnection);
}
}
}再給大家分享一個sqlhelper類
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient;
using System.Data;
namespace ADONET2
{
class SqlHelper
{
//封裝方法的原則,把不變的放在方法中,把變化的放在參數中傳進來
private static string connStr = ConfigurationManager.ConnectionStrings["dbConn"].ConnectionString;
//public static int ExecuteNonQuery(string sql)
//{
// using (SqlConnection conn = new SqlConnection(connStr))
// {
// conn.Open();
// using (SqlCommand cmd = conn.CreateCommand())
// {
// cmd.CommandText = sql;
// return cmd.ExecuteNonQuery();
// }
// }
//}
//public static object ExecuteScalar(string sql)
//{
// using (SqlConnection conn = new SqlConnection(connStr))
// {
// conn.Open();
// using (SqlCommand cmd = conn.CreateCommand())
// {
// cmd.CommandText = sql;
// return cmd.ExecuteScalar();
// }
// }
//}
//public static DataTable ExecuteDataTable(string sql)
//{
// using (SqlConnection conn = new SqlConnection(connStr))
// {
// conn.Open();
// using (SqlCommand cmd = conn.CreateCommand())
// {
// cmd.CommandText = sql;
// SqlDataAdapter adapter = new SqlDataAdapter(cmd);
// DataSet dataset = new DataSet();
// adapter.Fill(dataset);
// return dataset.Tables[0];
// }
// }
//}
public static int ExecuteNonQuery(string sql,params SqlParameter[] parameters)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
//foreach (SqlParameter param in parameters)
//{
// cmd.Parameters.Add(param);
//}
cmd.Parameters.AddRange(parameters);
return cmd.ExecuteNonQuery();
}
}
}
public static object ExecuteScalar(string sql,SqlParameter[] parameters)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
cmd.Parameters.AddRange(parameters);
return cmd.ExecuteScalar();
}
}
}
//public static DataTable ExecuteDataTable(string sql,SqlParameter[] parameters)
//{
// using (SqlConnection conn = new SqlConnection(connStr))
// {
// conn.Open();
// using (SqlCommand cmd = conn.CreateCommand())
// {
// cmd.CommandText = sql;
// cmd.Parameters.AddRange(parameters);
// SqlDataAdapter adapter = new SqlDataAdapter(cmd);
// DataSet dataset = new DataSet();
// adapter.Fill(dataset);
// return dataset.Tables[0];
// }
// }
//}
//使用可變參數
public static DataTable ExecuteDataTable(string sql, params SqlParameter[] parameters)
{
using (SqlConnection conn = new SqlConnection(connStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
cmd.Parameters.AddRange(parameters);
SqlDataAdapter adapter = new SqlDataAdapter(cmd);
DataSet dataset = new DataSet();
adapter.Fill(dataset);
return dataset.Tables[0];
}
}
}
}
}關于“C#如何編寫SqlHelper類”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。