详解使用C#编写SqlHelper类

详解使用C#编写SqlHelper类,第1张

概述无聊的周末,学习、编码无力。想找点事干但又不知道干点什么,猛然发现自己学过的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类全部内容,希望文章能够帮你解决详解使用C#编写SqlHelper类所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/1253948.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-07
下一篇2022-06-07

发表评论

登录后才能评论

评论列表(0条)

    保存