分享

数据库操作通用类

 weiledream 2012-05-31

非常不错的数据库操作通用类,原创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;
    }
}

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约