非常不错的数据库操作通用类,原创GMM。转过来备份,经常会用到
using System;
using System.Data;
using System.Configuration;
using System.Data.SqlClient;
/// <summary>
///针对sql server数据库操作的通用类
/// </summary>
public class SqlHelper
{
public SqlHelper()
{
//
//TODO: 在此处添加构造函数逻辑
//
connectionstring = ConfigurationManager.ConnectionStrings["MyDataBaseConStr"].ConnectionString;
}
private string connectionstring;
/// <summary>
/// 设置连接字符串
/// </summary>
public string Connectionstring
{
set { connectionstring = value; }
}
/// <summary>
/// 构造函数
/// </summary>
/// <param name="connectionstring">数据库连接字符串</param>
/// <returns></returns>
public SqlHelper(string connectionstring)
{
this.connectionstring = connectionstring;
}
/// <summary>
/// 执行一个查询,并返回结果集
/// </summary>
/// <param name="sql">要执行的查询sql文本命令</param>
/// <returns>返回查询结果集</returns>
public DataTable ExecuteDataTable(string sql)
{
return ExecuteDataTable(sql, CommandType.Text, null);
}
/// <summary>
/// 执行一个查询,并返回查询结果
/// </summary>
/// <param name="sql">要执行的sql语句</param>
/// <param name="commandType">要执行的查询语句的类型,如存储过程或sql文本命令</param>
/// <returns>返回查询结果集</returns>
public DataTable ExecuteDataTable(string sql, CommandType commandType)
{
return ExecuteDataTable(sql, commandType, null);
}
/// <summary>
/// 执行一个查询,并且返回查询结果
/// </summary>
/// <param name="sql">要执行的sql语句</param>
/// <param name="commandType">要执行的查询语句的类型,如存储过程或sql文本命令</param>
/// <param name="parameters">Transact-SQL语句或存储过程的参数数组</param>
/// <returns></returns>
public DataTable ExecuteDataTable(string sql, CommandType commandType, SqlParameter[] parameters)
{
DataTable data = new DataTable();//实例化datatable,用于装载查询结果集
using (SqlConnection connection = new SqlConnection(connectionstring))
{
using (SqlCommand command = new SqlCommand(sql, connection))
{
command.CommandType = commandType;//设置command的commandtype为制定的commandtype
//如果同时传入的参数,则添加这些参数
if (parameters != null)
{
foreach (SqlParameter parameter in parameters)
{
command.Parameters.Add(parameters);
}
}
//通过包含查询SQL的sqlcommand实例来实例化sqldataadapter
SqlDataAdapter adapter = new SqlDataAdapter(command);
adapter.Fill(data);//填充DataTable
}
}
return data;
}
/// <summary>
/// 返回一个sqldatareader对象的实例
/// </summary>
/// <param name="sql">要执行的查询sql文本命令</param>
/// <returns></returns>
public SqlDataReader ExecuteReader(string sql)
{
return ExecuteReader(sql, CommandType.Text, null);
}
/// <summary>
/// 返回一个sqldatareader对象的实例
/// </summary>
/// <param name="sql">要执行的查询sql文本命令</param>
/// <param name="commandtype">要执行的查询语句的类型,如存储过程或sql文本命令</param>
/// <returns></returns>
public SqlDataReader ExecuteReader(string sql, CommandType commandtype)
{
return ExecuteReader(sql, commandtype, null);
}
public SqlDataReader ExecuteReader(string sql, CommandType commandtype, SqlParameter[] parameters)
{
SqlConnection connection = new SqlConnection(connectionstring);
SqlCommand command = new SqlCommand(sql, connection);
//如果传入了参数,则添加这些参数
if (parameters != null)
{
foreach (SqlParameter parameter in parameters)
{
command.Parameters.Add(parameters);
}
}
connection.Open();
//CommandBehavior .CloseConnection参数指示关闭Reader对象时关闭与其关联的connection对象
return command.ExecuteReader(CommandBehavior.CloseConnection);
}
/// <summary>
/// 执行一个查询,返回查询结果集的第一行,忽略其他的行和列
/// </summary>
/// <param name="sql">要执行的查询sql文本命令</param>
/// <returns></returns>
public Object ExecuteScalar(string sql)
{
return ExecuteScalar(sql, CommandType.Text, null);
}
/// <summary>
/// 执行一个查询,返回查询结果集的第一行,忽略其他的行和列
/// </summary>
/// <param name="sql">要执行的SQL语句</param>
/// <param name="commandtype">要执行的查询语句的类型,如存储过程或sql文本命令</param>
/// <returns></returns>
public Object ExecuteScalar(string sql, CommandType commandtype)
{
return ExecuteScalar(sql, CommandType.Text, null);
}
public Object ExecuteScalar(string sql, CommandType commandtype, SqlParameter[] parameter)
{
object result = null;
using (SqlConnection connection = new SqlConnection(connectionstring))
{
using (SqlCommand command = new SqlCommand(sql, connection))
{
command.CommandType = commandtype;//设置command的commandtype为指定的commandtype
//如果同时传入了参数,则添加这些参数
if (parameter != null)
{
foreach (SqlParameter parameters in parameter)
{
command.Parameters.Add(parameter);
}
}
connection.Open();//打开数据库
result = command.ExecuteScalar();
}
}
return result;//返回查询结果的第一行和第一列,忽略其他行和列
}
/// <summary>
/// 对数据库实行增删改操作
/// </summary>
/// <param name="sql">要执行的查询Sql文本命令</param>
/// <returns></returns>
public int ExecuteNonQuery(string sql)
{
return ExecuteNonQuery(sql, CommandType.Text, null);
}
/// <summary>
/// 对数据库实行增删改操作
/// </summary>
/// <param name="sql">要执行的查询Sql文本命令</param>
/// <param name="commandtype">要执行的查询语句的类型,如存储过程或sql文本命令</param>
/// <returns></returns>
public int ExecuteNonQuery(string sql, CommandType commandtype)
{
return ExecuteNonQuery(sql, CommandType.Text, null);
}
/// <summary>
/// 对数据库实行增删改操作
/// </summary>
/// <param name="sql">要执行的查询Sql文本命令</param>
/// <param name="commandtype">要执行的查询语句的类型,如存储过程或sql文本命令</param>
/// <param name="parameters">要执行的查询语句的类型,如存储过程或sql文本命令</param>
/// <returns></returns>
public int ExecuteNonQuery(string sql, CommandType commandtype, SqlParameter[] parameters)
{
int count = 0;
using (SqlConnection connection = new SqlConnection(connectionstring))
{
using (SqlCommand command = new SqlCommand(sql, connection))
{
command.CommandType = commandtype;//设置command的commandtype为制定commandtype
//如果同时传入了参数,则添加这些参数
if (parameters != null)
{
foreach (SqlParameter parameter in parameters)
{
command.Parameters.Add(parameter);
}
}
connection.Open();//打开数据库连接
count = command.ExecuteNonQuery();
}
}
return count;//执行增删改查操作后,返回数据库中受影响的行数
}
/// <summary>
/// 返回当前连接的数据库中所有由用户创建的数据库
/// </summary>
/// <returns></returns>
public DataTable GetTables()
{
DataTable data = null;
using (SqlConnection connection = new SqlConnection(connectionstring))
{
connection.Open();//打开数据库连接
data = connection.GetSchema("Tables");
}
return data;
}
}