DbHelper

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text; namespace Asmkt.Database
{
    /// <summary>
    /// SQL数据库帮助
    /// </summary>
    public sealed class SqlDatabaseHelper
    {
        #region 属性
        /// <summary>
        /// 数据库连接字符串
        /// </summary>
        public string ConnectionString
        { get; set; }
        #endregion 属性         #region 构造函数
        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="configurationName">配置名称</param>
        public SqlDatabaseHelper(string configurationName = null)
        {
            ConnectionStringSettings config = ConfigurationManager.ConnectionStrings[0];
            if (!string.IsNullOrWhiteSpace(configurationName))
                config = ConfigurationManager.ConnectionStrings[configurationName];
            ConnectionString = config.ConnectionString;
        }
        #endregion 构造函数         #region 静态成员方法
        /// <summary>
        /// 通过指定的数据库连接获得数据库处理事务
        /// </summary>
        /// <param name="conn">数据库连接</param>
        /// <param name="transactionName">事务名称</param>
        /// <param name="isolationLevel">事务隔离级别</param>
        /// <returns>数据库处理事务</returns>
        public static SqlTransaction GetTransaction(
            SqlConnection conn,
            string transactionName=null,
            IsolationLevel isolationLevel= IsolationLevel.Chaos)
        {
            if (conn == null)
                return null;
            if (conn.State != System.Data.ConnectionState.Open)
                conn.Open();
            if (string.IsNullOrWhiteSpace(transactionName))
                return conn.BeginTransaction();
            else
                return conn.BeginTransaction(isolationLevel, transactionName);
        }
        /// <summary>
        /// 对连接执行Trans-SQL语句并返回受影响的行数
        /// </summary>
        /// <param name="conn">指定的数据库连接</param>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        /// <returns>受影响的行数</returns>
        public static int ExecuteNonQuery(
            SqlConnection conn,
            string sqlText,
            CommandType cmdType = CommandType.Text,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            int rslt = -1;
            using(SqlCommand cmd = new SqlCommand())
            {
                cmd.Connection = conn;
                cmd.CommandText = sqlText;
                cmd.CommandType = cmdType;
                cmd.CommandTimeout = connectionTimeout;
                cmd.Parameters.Clear();
                if (parameters.Length > 0)
                    cmd.Parameters.AddRange(parameters);
                if (conn.State != ConnectionState.Open)
                    conn.Open();
                rslt = cmd.ExecuteNonQuery(); 
            }
            return rslt;         }
        /// <summary>
        /// 执行查询,并返回查询返回结果集中的第一行的第一列,并忽略其他行或行
        /// </summary>
        /// <param name="conn">指定的数据库连接</param>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        /// <returns>查询结果集中的第一行的第一列</returns>
        public static object ExcuteScalar(
            SqlConnection conn,
            string sqlText,
            CommandType cmdType = CommandType.Text,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            object rslt = null;
            using (SqlCommand cmd = new SqlCommand())
            {
                cmd.Connection = conn;
                cmd.CommandText = sqlText;
                cmd.CommandType = cmdType;
                cmd.CommandTimeout = connectionTimeout;
                if (parameters.Length > 0)
                    cmd.Parameters.AddRange(parameters);
                if (conn.State != ConnectionState.Open)
                    conn.Open();
                rslt = cmd.ExecuteScalar();
            }
            return rslt;
        }
        /// <summary>
        /// 执行查询,并将单一结果集存储在DataTable中并返回
        /// </summary>
        /// <param name="conn">指定的数据库连接</param>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        /// <returns>查询结果集</returns>
        public static DataTable ExecuteDataTable(
            SqlConnection conn,
            string sqlText,
            CommandType cmdType = CommandType.Text,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            DataTable rslt = null;
            using (SqlCommand cmd = new SqlCommand())
            {
                cmd.Connection = conn;
                cmd.CommandText = sqlText;
                cmd.CommandType = cmdType;
                cmd.CommandTimeout = connectionTimeout;
                if (parameters.Length > 0)
                    cmd.Parameters.AddRange(parameters);
                if (conn.State != ConnectionState.Open)
                    conn.Open();
                using(SqlDataReader reader = cmd.ExecuteReader())
                {
                    rslt = new DataTable();
                    rslt.Load(reader);
                }
            }
            return rslt;
        }
        /// <summary>
        /// 执行查询,并将结果集填充到指定的表中
        /// </summary>
        /// <param name="conn">指定的数据库连接</param>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="datatable">要填充的表</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="loadOption">指示已存在于datatable的行如何与共享主键的传入行合并</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        public static void FillDataTable(
            SqlConnection conn,
            string sqlText,
            ref DataTable datatable,
            CommandType cmdType = CommandType.Text,
            LoadOption loadOption = LoadOption.PreserveChanges,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            using (SqlCommand cmd = new SqlCommand())
            {
                cmd.Connection = conn;
                cmd.CommandText = sqlText;
                cmd.CommandType = cmdType;
                cmd.CommandTimeout = connectionTimeout;
                if (parameters.Length > 0)
                    cmd.Parameters.AddRange(parameters);
                if (conn.State != ConnectionState.Open)
                    conn.Open();
                using (SqlDataReader reader = cmd.ExecuteReader())
                    datatable.Load(reader, loadOption);
            }
        }         /// <summary>
        /// 将指定表中的数据存储到数据库中
        /// </summary>
        /// <param name="conn">数据库连接</param>
        /// <param name="dataTable">等存储的数据</param>
        /// <param name="destinationTableName">存储的目标表</param>
        /// <param name="batchSize">每一批次的行数,在每一批次结束时,将该批次的行发送到服务器</param>
        /// <param name="ConnectionTimeout">超时之前操作完成所允许的秒数</param>
        /// <param name="rowState">只在匹配状态的行才会复制到目标表中</param>
        /// <param name="columnMapping">列映射关系</param>
        public static void SaveData(
            SqlConnection conn,
            ref DataTable dataTable,
            string destinationTableName = null,
            int batchSize = 500,
            int ConnectionTimeout = 30,
            DataRowState rowState = DataRowState.Added,
            params SqlBulkCopyColumnMapping[] columnMapping)
        {
            using(SqlBulkCopy sqlBulkCopy = new SqlBulkCopy(conn))
            {
                sqlBulkCopy.BulkCopyTimeout = ConnectionTimeout;
                sqlBulkCopy.BatchSize = batchSize;
                if (string.IsNullOrWhiteSpace(destinationTableName))
                    sqlBulkCopy.DestinationTableName = dataTable.TableName;
                else
                    sqlBulkCopy.DestinationTableName = destinationTableName;
                foreach (SqlBulkCopyColumnMapping item in columnMapping)
                    sqlBulkCopy.ColumnMappings.Add(item);
                sqlBulkCopy.WriteToServer(dataTable,rowState);
            }
        }
        #endregion 表态成员方法         #region 成员方法
        /// <summary>
        /// 获得数据库连接
        /// </summary>
        /// <returns>返回数据库连接</returns>
        public SqlConnection GetConnection()
        {
            return new SqlConnection(ConnectionString);
        }         /// <summary>
        /// 对连接执行Trans-SQL语句并返回受影响的行数
        /// </summary>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        /// <returns>受影响的行数</returns>
        public int ExecuteNonQuery(
            string sqlText,
            CommandType cmdType = CommandType.Text,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            using (SqlConnection conn = GetConnection())
                return ExecuteNonQuery(conn, sqlText, cmdType, connectionTimeout, parameters);
        }         /// <summary>
        /// 执行查询,并返回查询返回结果集中的第一行的第一列,并忽略其他行或行
        /// </summary>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        /// <returns>查询结果集中的第一行的第一列</returns>
        public object ExcuteScalar(
            string sqlText,
            CommandType cmdType = CommandType.Text,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            using (SqlConnection conn = GetConnection())
                return ExcuteScalar(conn, sqlText, cmdType, connectionTimeout, parameters);
        }
        /// <summary>
        /// 执行查询,并将单一结果集存储在DataTable中并返回
        /// </summary>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        /// <returns>查询结果集</returns>
        public DataTable ExecuteDataTable(
            string sqlText,
            CommandType cmdType = CommandType.Text,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            using (SqlConnection conn = GetConnection())
                return ExecuteDataTable(conn, sqlText, cmdType, connectionTimeout, parameters);
        }
        /// <summary>
        /// 执行查询,并将结果集填充到指定的表中
        /// </summary>
        /// <param name="sqlText">执行的语句、存储过程或表名</param>
        /// <param name="datatable">要填充的表</param>
        /// <param name="cmdType">如何解释sqlText的属性</param>
        /// <param name="loadOption">指示已存在于datatable的行如何与共享主键的传入行合并</param>
        /// <param name="connectionTimeout">终止执行命令的尝试生成错误之前等待的时间</param>
        /// <param name="parameters">使用的参数集合</param>
        public void FillDataTable(
            string sqlText,
            ref DataTable datatable,
            CommandType cmdType = CommandType.Text,
            LoadOption loadOption = LoadOption.PreserveChanges,
            int connectionTimeout = 30,
            params SqlParameter[] parameters)
        {
            using (SqlConnection conn = GetConnection())
                FillDataTable(conn, sqlText, ref datatable, cmdType, loadOption, connectionTimeout, parameters);
        }         /// <summary>
        /// 将指定表中的数据存储到数据库中
        /// </summary>
        /// <param name="dataTable">等存储的数据</param>
        /// <param name="destinationTableName">存储的目标表</param>
        /// <param name="batchSize">每一批次的行数,在每一批次结束时,将该批次的行发送到服务器</param>
        /// <param name="ConnectionTimeout">超时之前操作完成所允许的秒数</param>
        /// <param name="rowState">只在匹配状态的行才会复制到目标表中</param>
        /// <param name="columnMapping">列映射关系</param>
        public void SaveData(
            ref DataTable dataTable,
            string destinationTableName = null,
            int batchSize = 500,
            int ConnectionTimeout = 30,
            DataRowState rowState = DataRowState.Added,
            params SqlBulkCopyColumnMapping[] columnMapping)
        {
            using (SqlConnection conn = GetConnection())
                SaveData(conn, ref dataTable,destinationTableName, batchSize, ConnectionTimeout, rowState, columnMapping);
        }
        #endregion 成员方法
    }
}
上一篇:第十四天 第十一章 SQLite3数据库


下一篇:dapper 异步修改方法