好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

  }

}

}

再给大家分享一个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];

   }

   }

  }

  }

}

原文链接:http://HdhCmsTestcnblogs测试数据/AMortal/p/7538443.html

dy("nrwz");

查看更多关于C#编写SqlHelper类的详细内容...

  阅读:50次