微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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); 
    }
  }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐