虚位以待(AD)
虚位以待(AD)
首页 > 软件编程 > C#编程 > C#编写SqlHelper类

C#编写SqlHelper类
类别:C#编程   作者:码皇   来源:互联网   点击:

在C 中使用ADO NET连接数据库的时候,每次连接都要编写连接,打开,执行SQL语句的代码,很麻烦,编写一个SqlHelper类,把每次连接都要写的代码封装成方法,把要执行的SQL语句通过参数传进去,可以大大简化编码

无聊的周末,学习、编码无力。想找点事干但又不知道干点什么,猛然发现自己学过的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#实现操作MySql数据层类MysqlHelper实例
  • C#基于SQLiteHelper类似SqlHelper类实现存取Sqlite数据库的方法
  • 详解使用C#编写SqlHelper类
  • C#实现较为实用的SQLhelper
  • c#中SqlHelper封装SqlDataReader的方法
  • C# SqlHelper应用开发学习
  • C# Oracle数据库操作类实例详解
  • c#连接access数据库操作类分享
  • C#数据库操作类AccessHelper实例
  • C#实现的ACCESS数据库操作类完整实例
  • C#实现的封装CURD到SqlHelper类用法简单分析
相关热词搜索: C SqlHelper类 C 实现 SQLhelper c 中sql