设为首页 收藏本站
查看: 680|回复: 0

[经验分享] C#下一个SQL SERVER数据库操作类

[复制链接]

尚未签到

发表于 2015-7-4 14:25:38 | 显示全部楼层 |阅读模式
主要参考了M$的SqlHelper类,
在参考了SqlHelper的基础进行修改而成,对一些基本的数据库操作进行了封装.
推荐使用

using (DBHelper db = new DBHelper(Config.ConnStr))
{
}代码如下:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data.SqlClient;
using System.Data;

namespace Liydotnet.Data.Core
{
    public class DBHelper : IDisposable
    {
        #region private
        private bool m_AlreadyDispose = false;
        private int m_CommandTimeout = 30;
        private string m_ConnStr;
        private SqlConnection m_Connection;
        private SqlCommand m_Command;
        #endregion
        #region 属性
        ///
        /// 数据库连接字符串
        ///
        public string ConnStr
        {
            set { m_ConnStr = value; }
            get { return m_ConnStr; }
        }
        ///
        /// 执行时间
        ///
        public int CommandTimeout
        {
            set { m_CommandTimeout = value; }
            get { return m_CommandTimeout; }
        }
        #endregion
        #region DBHelper
        ///
        /// 构造函数
        ///
        /// 数据库连接字符串
        public DBHelper(string connStr)
        {
            m_ConnStr = connStr;
            Initialization();
        }
        ///
        /// 构造函数
        ///
        /// 数据库连接字符串
        /// 执行时间
        public DBHelper(string connStr, int commandTimeout)
        {
            m_ConnStr = connStr;
            m_CommandTimeout = commandTimeout;
            Initialization();
        }
        ///
        /// 初始化函数
        ///
        protected void Initialization()
        {
            try
            {
                m_Connection = new SqlConnection(m_ConnStr);
                if (m_Connection.State == ConnectionState.Closed)
                    m_Connection.Open();
                m_Command = new SqlCommand();
            }
            catch (Exception ex)
            {
                throw new Exception(ex.Message.ToString());
            }
        }
        #endregion
        #region Dispose
        ///
        /// 析构函数
        ///
        ~DBHelper()
        {
            Dispose(false);
        }
        ///
        ///  释放资源
        ///
        /// 标志
        protected virtual void Dispose(bool isDisposing)
        {
            if (m_AlreadyDispose) return;
            if (isDisposing)
            {
                if (m_Command != null)
                {
                    m_Command.Cancel();
                    m_Command.Dispose();
                }
                if (m_Connection != null)
                {
                    try
                    {
                        if (m_Connection.State != ConnectionState.Closed)
                            m_Connection.Close();
                        m_Connection.Dispose();
                    }
                    catch (Exception ex)
                    {
                        throw new Exception(ex.ToString());
                    }
                    finally
                    {
                        m_Connection = null;
                    }
                }
            }
            m_AlreadyDispose = true;//已经进行的处理
        }
        ///
        /// 释放资源
        ///
        public void Dispose()
        {
            Dispose(true);
            GC.SuppressFinalize(this);
        }
        #endregion
        #region
        #endregion
        #region ExecuteNonQuery
        public int ExecuteNonQuery(string cmdText)
        {
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                int iRet = m_Command.ExecuteNonQuery();
                return iRet;
            }
            catch (Exception ex)
            {
                //Loger.Debug(ex.ToString(),@"C:\sql.txt");
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
            }
        }
        public int ExecuteNonQuery(string cmdText, SqlParameter[] para)
        {
            if (para == null)
            {
                return ExecuteNonQuery(cmdText);
            }
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                for (int i = 0; i < para.Length; i++)
                    m_Command.Parameters.Add(para);
                int iRet = m_Command.ExecuteNonQuery();
                return iRet;
            }
            catch (Exception ex)
            {
                //Loger.Debug(ex.ToString(), @"C:\sql.txt");
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                m_Command.Parameters.Clear();
            }
        }
        public int ExecuteNonQuery(string cmdText, SqlParameter[] para, bool isStoreProdure)
        {
            if (!isStoreProdure)
            {
                return ExecuteNonQuery(cmdText, para);
            }
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                m_Command.CommandType = CommandType.StoredProcedure;
                if (para != null)
                {
                    for (int i = 0; i < para.Length; i++)
                        m_Command.Parameters.Add(para);
                }
                int iRet = m_Command.ExecuteNonQuery();
                return iRet;
            }
            catch (Exception ex)
            {
                //Loger.Debug(ex.ToString(), @"C:\sql.txt");
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                m_Command.Parameters.Clear();
            }
        }
        #endregion
        #region ExecuteTransaction
        public bool ExecuteTransaction(string[] cmdText)
        {
            SqlTransaction trans = m_Connection.BeginTransaction();
            try
            {
                m_Command = new SqlCommand();
                m_Command.Connection = m_Connection;
                m_Command.CommandTimeout = m_CommandTimeout;
                m_Command.Transaction = trans;
                for (int i = 0; i < cmdText.Length; i++)
                {
                    if (cmdText != null && cmdText != string.Empty)
                    {
                        m_Command.CommandText = cmdText;
                        m_Command.ExecuteNonQuery();
                    }
                }
                trans.Commit();
                return true;
            }
            catch (Exception ex)
            {
                trans.Rollback();
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                trans.Dispose();
            }
        }
        public bool ExecuteTransaction(string[] cmdText, SqlParameter[] para)
        {
            if (para == null)
                return ExecuteTransaction(cmdText);
            SqlTransaction trans = m_Connection.BeginTransaction();
            try
            {
                m_Command = new SqlCommand();
                m_Command.Connection = m_Connection;
                m_Command.CommandTimeout = m_CommandTimeout;
                m_Command.Transaction = trans;
                for (int i = 0; i < para.Length; i++)
                    m_Command.Parameters.Add(para);
                for (int i = 0; i < cmdText.Length; i++)
                {
                    if (cmdText != null && cmdText != string.Empty)
                    {
                        m_Command.CommandText = cmdText;
                        m_Command.ExecuteNonQuery();
                    }
                }
                trans.Commit();
                return true;
            }
            catch (Exception ex)
            {
                trans.Rollback();
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                trans.Dispose();
            }
        }
        #endregion
        #region ExecuteScalar
        public object ExecuteScalar(string cmdText)
        {
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                object obj = m_Command.ExecuteScalar();
                if (object.Equals(obj, null) || object.Equals(obj, DBNull.Value))
                {
                    obj = null;
                }
                return obj;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
            }
        }
        public object ExecuteScalar(string cmdText, SqlParameter[] para)
        {
            if (para == null)
                return ExecuteScalar(cmdText);
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                for (int i = 0; i < para.Length; i++)
                    m_Command.Parameters.Add(para);
                object obj = m_Command.ExecuteScalar();
                if (object.Equals(obj, null) || object.Equals(obj, DBNull.Value))
                    obj = null;
                return obj;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                m_Command.Parameters.Clear();
            }
        }
        public object ExecuteScalar(string cmdText, SqlParameter[] para, bool isStoreProdure)
        {
            if (!isStoreProdure)
                return ExecuteScalar(cmdText, para);
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                m_Command.CommandType = CommandType.StoredProcedure;
                if (para != null)
                    for (int i = 0; i < para.Length; i++)
                        m_Command.Parameters.Add(para);
                object obj = m_Command.ExecuteScalar();
                if (object.Equals(obj, null) || object.Equals(obj, DBNull.Value))
                    obj = null;
                return obj;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                {
                    m_Command.Dispose();
                }
                m_Command.Parameters.Clear();
            }
        }
        #endregion
        #region ExecuteDataTable
        public DataTable ExecuteDataTable(string tableName, string cmdText)
        {
            try
            {
                DataTable myTable = new DataTable(tableName);
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                SqlDataAdapter da = new SqlDataAdapter(m_Command);
                da.Fill(myTable);
                da.Dispose();
                return myTable;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
            }
        }
        public DataTable ExecuteDataTable(string tableName, string cmdText, SqlParameter[] para)
        {
            if (para == null)
                return ExecuteDataTable(tableName, cmdText);
            try
            {
                DataTable myTable = new DataTable(tableName);
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                for (int i = 0; i < para.Length; i++)
                    m_Command.Parameters.Add(para);
                SqlDataAdapter da = new SqlDataAdapter(m_Command);
                da.Fill(myTable);
                da.Dispose();
                return myTable;
            }
            catch (Exception ex)
            {
                //Loger.Debug(ex.ToString(), @"C:\sql.txt");
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                m_Command.Parameters.Clear();
            }
        }
        public DataTable ExecuteDataTable(string tableName, string cmdText, SqlParameter[] para, bool isStoreProdure)
        {
            if (!isStoreProdure)
            {
                return ExecuteDataTable(tableName, cmdText, para);
            }
            try
            {
                DataTable myTable = new DataTable(tableName);
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                m_Command.CommandType = CommandType.StoredProcedure;
                if (para != null)
                    for (int i = 0; i < para.Length; i++)
                        m_Command.Parameters.Add(para);
                SqlDataAdapter da = new SqlDataAdapter(m_Command);
                da.Fill(myTable);
                da.Dispose();
                return myTable;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                m_Command.Parameters.Clear();
            }

        }
        #endregion
        #region ExecuteDataReader
        public SqlDataReader ExecuteDataReader(string cmdText)
        {
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                SqlDataReader reader = m_Command.ExecuteReader();
                return reader;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
            }
        }
        public SqlDataReader ExecuteDataReader(string cmdText, SqlParameter[] para)
        {
            if (para == null)
            {
                return ExecuteDataReader(cmdText);
            }
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                for (int i = 0; i < para.Length; i++)
                    m_Command.Parameters.Add(para);
                SqlDataReader reader = m_Command.ExecuteReader();
                return reader;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                m_Command.Parameters.Clear();
            }
        }
        public SqlDataReader ExecuteDataReader(string cmdText, SqlParameter[] para, bool isStoreProdure)
        {
            if (!isStoreProdure)
            {
                return ExecuteDataReader(cmdText, para);
            }
            try
            {
                m_Command = new SqlCommand(cmdText, m_Connection);
                m_Command.CommandTimeout = m_CommandTimeout;
                m_Command.CommandType = CommandType.StoredProcedure;
                if (para != null)
                    for (int i = 0; i < para.Length; i++)
                        m_Command.Parameters.Add(para);
                SqlDataReader reader = m_Command.ExecuteReader();
                return reader;
            }
            catch (Exception ex)
            {
                throw new Exception(ex.ToString());
            }
            finally
            {
                if (m_Command != null)
                    m_Command.Dispose();
                m_Command.Parameters.Clear();
            }
        }
        #endregion
        #region  Static
        public static SqlParameter MakeInParam(string paraName, SqlDbType paraType, object value)
        {
            SqlParameter para = new SqlParameter(paraName, paraType);
            if (Object.Equals(value, null) || Object.Equals(value, DBNull.Value) || value.ToString().Trim() == string.Empty)
                para.Value = DBNull.Value;
            else
                para.Value = value;
            return para;
        }
        public static SqlParameter MakeInParam(string paraName, SqlDbType paraType, int len, object value)
        {
            SqlParameter para = new SqlParameter(paraName, paraType, len);
            if (Object.Equals(value, null) || Object.Equals(value, DBNull.Value) || value.ToString().Trim() == string.Empty)
                para.Value = DBNull.Value;
            else
                para.Value = value;
            return para;
        }
         #endregion
    }
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-83109-1-1.html 上篇帖子: 安装 SQL Server 2008 Management Studio Express 下篇帖子: SQL Server 2008空间数据库 应用程序开发演练
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表