C#编写SqlHelper类的使用详解

互联网 17-9-18
本篇文章主要介绍了使用C#编写SqlHelper类,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

无聊的周末,学习、编码无力。想找点事干但又不知道干点什么,猛然发现自己学过的SqlHelper快忘记了。于是乎虎躯一震心想怎能如此堕落下去,立马打开电脑,双手摸上键盘。写下此文作为学习过程中的复习,并分享出知识(顺便打发时间-^.^-)。

下面开始正文

<connectionStrings>     <add name="Sql" connectionString="server=数据库地址;uid=用户名;pwd=密码;database=数据库名"/>    </connectionStrings>

1.接着需要创建一个名为SqlHepler类,然后创建一个方法来获取app.config文件中配置的连接字符串。

public static string GetSqlConnectionString()   {     return ConfigurationManager.       ConnectionStrings["Sql"].ConnectionString;   }
 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:需要的参数集合

该方法主要是用于执行,删除、更新和插入操作,返回受影响的行数。

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将被填充查询出来的数据,然后返回数据。

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类的使用详解的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: csharp
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:C#中Socket框架的使用教程

相关资讯