简单的DBHelper类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Configuration;
using System.Data.SqlClient;
using System.Data;//using: 引入命名空间

namespace DBHelper
{
    public static class DBHelper
    {
        //Web.config 配置
        // <?xml version="1.0"?>
        //
        //    <configuration>
        //
        //        <!--指定配置节和命名空间声明。clear:移除对继承的节和节组的所有引用,只允许由当前 section 和 sectionGroup 元素添加的节和节组。remove:移除对继承的节和节组的引用。section:定义配置节处理程序与配置元素之间的关联。sectionGroup:定义配置节处理程序与配置节之间的关联。-->
        //      <configSections>
        //        ............
        //      </configSections>
        //
        //      <!--appSettings是应用程序设置,可以定义应用程序的全局常量设置等信息-->
        //      <appSettings>
        //            ..............
        //     </appSettings>
        //
        //     <!--连接字符串设置-->
        //      <connectionStrings>
        //        <add name="strCon" connectionString="Data Source=CUSTDB;user=HISSG_AG;password=HISSG_AG;"/>
        //      </connectionStrings>
        //
        //      <system.web>
              
        //      </system.web>
        //      .................
        //      .................
        //    </configuration>


        //要引入using System.Configuration命名空间
        private static readonly string connectionString = ConfigurationManager.ConnectionStrings["strCon"].ConnectionString;

        /// <summary>
        ///  执行SQL语句,返回受影响的行数(用于insert,delete,update等)
        /// </summary>
        /// <param name="strSQL">SQL语句</param>
        /// <returns>受影响的行数</returns>
        public static int ExecuteSql(string strSQL)
        {
            //using: 释放资源
            //SqlConnection: 连接数据源
            //connectionString:用于连接数据源的字符串
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                //SqlCommand对数据源执行SQl命令
                //SqlCommand(CommandText, CommandString):strSQL需执行的SQL命令字符串,conn指定执行SQL命令需连接的数据源
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        int rows = cmd.ExecuteNonQuery();//执行SQL语句,返回受影响的行数。如rows>0,说明执行成功
                        return rows;
                    }
                    catch (System.Data.SqlClient.SqlException e)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw e;
                    }
                }
            }
        }

        /// <summary>
        /// 执行带参数的非查询SQL
        /// </summary>
        /// <param name="strSQL">SQL语句</param>
        /// <param name="values">参数</param>
        /// <returns>受影响行数</returns>
        public static int ExecuteCommand(string strSQL, params SqlParameter[] values)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        cmd.Parameters.AddRange(values);
                        int rows = cmd.ExecuteNonQuery();//执行SQL语句,返回受影响的行数。如rows>0,说明执行成功
                        return rows;
                    }
                    catch (System.Data.SqlClient.SqlException ex)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
                    }
                }
            }
        }

        /// <summary>
        ///  执行查询SQL语句,返回SqlDataReader(只进记录集) ( 注意:调用该方法后,一定要对SqlDataReader进行Close )
        /// </summary>
        /// <param name="strSQL">查询语句</param>
        /// <returns>SqlDataReader</returns>
        public static SqlDataReader ExecuteReader(string strSQL)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        //CommandBehavior.CloseConnection 能够保证当SqlDataReader对象被关闭时,其依赖的连接也会被自动关闭。
                        SqlDataReader myReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
                        return myReader;
                    }
                    catch (System.Data.SqlClient.SqlException ex)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
                    }
                }
            }
        }

        /// <summary>
        ///  执行带参数的查询SQL语句,返回SqlDataReader ( 注意:调用该方法后,一定要对SqlDataReader进行Close )
        /// </summary>
        /// <param name="strSQL">查询语句</param>
        /// <param name="values">参数</param>
        /// <returns>SqlDataReader</returns>
        public static SqlDataReader ExecuteReader(string strSQL, params SqlParameter[] values)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        //CommandBehavior.CloseConnection 能够保证当SqlDataReader对象被关闭时,其依赖的连接也会被自动关闭。
                        cmd.Parameters.AddRange(values);
                        SqlDataReader myReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
                        return myReader;
                    }
                    catch (System.Data.SqlClient.SqlException ex)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
                    }
                }
            }
        }


        ///////DataReader和DataSet的区别
        ///////1.获取数据的方式:
        ///////    DataReader(在线-一直占用SqlConnection连接,其它操作就可以不可使用,占用内存较小)
        ///////    DataSet(离线-将数据一次性读入内存,然后断开连接,其它操作就可以使用,比较消耗资源)
        ///////2.获取数据的机制
        ///////    DataReader是通过IDbCommand.ExecuteReader来读取数据。
        ///////    DataSet则是通过DbDataAdapter.Fill来填充数据
        ///////3.其它区别
        ///////    DataReader读取速度快于DataSet。
        ///////    DataReader是数据提供者类,DataSet是一般性类,借助于DbDataAdapter来填充数据。
        ///////...............................等


        /// <summary>
        ///  执行查询SQL语句,返回离线记录集
        /// </summary>
        /// <param name="strSQL">SQL语句</param>
        /// <returns>离线记录DataSet</returns>
        public DataSet getDataTablebySQL(string strSQL)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        DataSet ds = new DataSet();
                        SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
                        myAdapter.Fill(ds);
                        return ds;
                    }
                    catch (System.Data.SqlClient.SqlException ex)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
                    }
                }
            }
        }

        /// <summary>
        ///  执行带参数的查询SQL,返回离线记录集
        /// </summary>
        /// <param name="strSQL"></param>
        /// <returns></returns>
        public DataSet getDataTablebySQL(string strSQL, params SqlParameter[] values)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        DataSet ds = new DataSet();
                        cmd.Parameters.AddRange(values);
                        SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
                        myAdapter.Fill(ds);
                        return ds;
                    }
                    catch (System.Data.SqlClient.SqlException ex)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
                    }
                }
            }
        }

        /// <summary>
        ///  执行查询SQL语句,返回离线记录集
        /// </summary>
        /// <param name="strSQL">SQL语句</param>
        /// <returns>离线记录DataSet</returns>
        public DataTable getDataTablebySQL(string strSQL)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        DataSet ds = new DataSet();
                        SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
                        myAdapter.Fill(ds);
                        return ds.Tables[0];
                    }
                    catch (System.Data.SqlClient.SqlException ex)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
                    }
                }
            }
        }

        /// <summary>
        ///  执行带参数的查询SQL,返回离线记录集
        /// </summary>
        /// <param name="strSQL"></param>
        /// <returns></returns>
        public DataTable getDataTablebySQL(string strSQL,params SqlParameter[] values)
        {
            using (SqlConnection conn = new SqlConnection(connectionString))
            {
                using (SqlCommand cmd = new SqlCommand(strSQL, conn))
                {
                    try
                    {
                        conn.Open();//打开数据源连接
                        DataSet ds = new DataSet();
                        cmd.Parameters.AddRange(values);
                        SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
                        myAdapter.Fill(ds);
                        return ds.Tables[0];
                    }
                    catch (System.Data.SqlClient.SqlException ex)
                    {
                        conn.Close();//出异常,关闭数据源连接
                        throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
                    }
                }
            }
        }
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值