首页后端开发ASP.NETC#编写SqlHelper类的使用详解

C#编写SqlHelper类的使用详解

时间2024-01-30 18:32:03发布访客分类ASP.NET浏览517
导读:收集整理的这篇文章主要介绍了C#编写SqlHelper类的使用详解,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章主要介绍了使用C#编写SQLHelPEr类,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看...
收集整理的这篇文章主要介绍了C#编写SqlHelper类的使用详解,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章主要介绍了使用C#编写SQLHelPEr类,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

无聊的周末,学习、编码无力。想找点事干但又不知道干点什么,猛然发现自己学过的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);
     }
  }
}
    

以上就是C#编写SqlHelper类的使用详解的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

csharpSqlHelper

若转载请注明出处: C#编写SqlHelper类的使用详解
本文地址: https://pptw.com/jishu/592884.html
ASP.NET MVC如何使用Bootstrap的实例分析 jquery怎么从末尾移除一个元素

游客 回复需填写必要信息