一个SqlHealper方法 进行数据库交互集成

本文介绍了一个SQLHelper类的实现,该类提供与数据库交互的方法,包括执行存储过程并返回数据表或非查询操作。文章提供了完整的C#代码示例。

第一次尝试写技术类的文章,请大家多多指教!

这次主要写的是一个SqlHealper类,用于与数据库交互操作(select、update、delete);

代码如下:

public class SqlHealper
    {
        private bool successFlag;
        public bool SuccessFlag
        {
            get { return successFlag; }
        }

        private string strErrMessage;
        public string StrErrMessage
        {
            get { return strErrMessage; }
        }

        private SqlConnection comConn;
        private SqlCommand comCmd;
        private SqlDataAdapter comDa;
        private DataTable comDt;
        private DataSet comDs;

        /// <summary>
        /// 获取默认的连接字符串
        /// </summary>
        /// <returns></returns>
        private string GetDefaultConnString()
        {
            //return System.Configuration.ConfigurationManager.AppSettings["UserConnectionString"].ToString();
            return "server=(local);database=UserDB;uid=sa;pwd=sa";
        }

       
        private void PrepareCommand(SqlCommand cmd, SqlConnection conn, CommandType cmdType, string cmdText, SqlParameter[] cmdParms)
        {
            cmd.Connection = conn;
            cmd.CommandText = cmdText;
            cmd.CommandType = cmdType;
            if (cmdParms != null)
            {
                foreach (SqlParameter objCmdPara in cmdParms)
                {
                    cmd.Parameters.Add(objCmdPara);
                }
            }
        }

        public DataTable Execute_Return_DataTable(string strSP, SqlParameter[] pms)
        {
            try
            {
                comConn = new SqlConnection(GetDefaultConnString());
                comDt = new DataTable();
                if (comConn.State == ConnectionState.Closed)
                {
                    comConn.Open();
                }
                comCmd = new SqlCommand();
                PrepareCommand(comCmd, comConn, CommandType.StoredProcedure, strSP, pms);
                comDa = new SqlDataAdapter(comCmd);
                comDa.Fill(comDt);
                successFlag = true;

                return comDt;
            }
            catch (System.Exception ex)
            {
                successFlag = false;
                strErrMessage = ex.Message; 
                return comDt;
            }
            finally
            {
                comCmd.Dispose();
                comConn.Close();
                comConn.Dispose();
            }
        }

        public void Execute_Non_Query(string strSP, SqlParameter[] pms)
        {
            try
            {
                comConn = new SqlConnection(GetDefaultConnString());
                if (comConn.State == ConnectionState.Closed)
                {
                    comConn.Open();
                }
                comCmd = new SqlCommand();
                PrepareCommand(comCmd, comConn, CommandType.StoredProcedure, strSP, pms);
                comCmd.ExecuteNonQuery();
                successFlag = true;
            }
            catch (System.Exception ex)
            {
                successFlag = false;
                strErrMessage = ex.Message;
            }
            finally
            {
                
                comCmd.Dispose();
                comConn.Close();
                comConn.Dispose();
            }
        }

    }

 

 

 

  

 

转载于:https://www.cnblogs.com/yuxian2002/archive/2013/05/17/3084027.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值