一. DBHelper帮助类

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

using System.Data;

using System.Data.SqlClient;

using System.Configuration;

namespace DAL

{

    /// <summary>

    /// 数据库操作帮助类

    /// </summary>

    public class DBHelper

    {

        //连接字符串,从web.config中获取

        public static string conStr = ConfigurationManager.ConnectionStrings["DBConnectionString1"].ConnectionString;

        /// <summary>

        /// 获取SqlCommand对象

        /// </summary>

        /// <param name="sql">sql语句</param>

        /// <param name="conn">数据库连接对象</param>

        /// <param name="pars">参数集</param>

        /// <returns>SqlCommand对象</returns>

        private static SqlCommand GetSqlCommand(string sql, SqlConnection conn, params SqlParameter[] pars)

        {

            conn.Open();

            SqlCommand comm = new SqlCommand(sql, conn);

            comm.Parameters.AddRange(pars);

            return comm;

        }

        /// <summary>

        /// 设置SqlCommand对象的值

        /// </summary>

        /// <param name="comm">SqlCommand对象</param>

        /// <param name="commandText">需要执行的sql语句或存储过程名称</param>

        /// <param name="conn">数据库连接对象</param>

        /// <param name="type">执行的类型(sql语句类型或存储过程类型)</param>

        private static void SetSqlCommand(SqlCommand comm, string commandText, SqlConnection conn, CommandType type)

        {

            comm.CommandText = commandText;

            comm.Connection = conn;

            comm.CommandType = type;

        }

        /// 查询返回SqlDataReader,读取数据完毕后必须关闭SqlDataReader,会自动释放数据库连接

        /// </summary>

        /// <param name="sql">sql语句</param>

        /// <param name="pars">参数集</param>

        /// <returns>SqlDataReader</returns>

        public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] pars)

        {

            SqlConnection conn = new SqlConnection(conStr);

            SqlCommand comm = GetSqlCommand(sql, conn, pars);

            return comm.ExecuteReader(CommandBehavior.CloseConnection);

        }

        /// <summary>

        /// 执行查询,返回结果集的第一行第一列数据

        /// </summary>

        /// <param name="sql">sql语句</param>

        /// <param name="pars">参数集</param>

        /// <returns>单个数据</returns>

        public static object ExecuteScalar(string sql, params SqlParameter[] pars)

        {

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                SqlCommand comm = GetSqlCommand(sql, conn, pars);

                return comm.ExecuteScalar();

            }

        }

        /// <summary>

        /// 执行增删改操作

        /// </summary>

        /// <param name="sql">sql语句</param>

        /// <param name="pars">参数集</param>

        /// <returns>受影响的行数</returns>

        public static int ExecuteNonQuery(string sql, params SqlParameter[] pars)

        {

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                SqlCommand comm = GetSqlCommand(sql, conn, pars);

                return comm.ExecuteNonQuery();

            }

        }

        /// <summary>

        /// 执行查询语句,返回DataTable

        /// </summary>

        /// <param name="sql">sql语句</param>        

        /// <param name="pars">参数集</param>

        /// <returns>DataTable</returns>

        public static DataTable ExecuteAdapter(string sql, params SqlParameter[] pars)

        {

            DataTable dt = new DataTable();

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);

                adapter.SelectCommand.Parameters.AddRange(pars);

                adapter.Fill(dt);

            }

            return dt;

        }

        /// 调用存储过程返回SqlDataReader,读取数据完毕后必须关闭SqlDataReader,会自动释放数据库连接

        /// </summary>

        /// <param name="procedureName">存储过程名称</param>

        /// <param name="comm">Sqlcommand对象</param>

        /// <returns>SqlDataReader</returns>

        public static SqlDataReader ExecuteReader(string procedureName, SqlCommand comm)

        {

            SqlConnection conn = new SqlConnection(conStr);

            SetSqlCommand(comm, procedureName, conn, CommandType.StoredProcedure);

            return comm.ExecuteReader(CommandBehavior.CloseConnection);

        }

        /// <summary>

        /// 调用存储过程,返回结果集的第一行第一列数据

        /// </summary>

        /// <param name="procedureName">存储过程名称</param>

        /// <param name="comm">Sqlcommand对象</param>

        /// <returns>单个数据</returns>

        public static object ExecuteScalar(string procedureName, SqlCommand comm)

        {

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                SetSqlCommand(comm, procedureName, conn, CommandType.StoredProcedure);

                return comm.ExecuteScalar();

            }

        }

        /// <summary>

        /// 调用存储过程,执行非查询操作(增删改)

        /// </summary>

        /// <param name="procedureName">存储过程名称</param>

        /// <param name="comm">Sqlcommand对象</param>

        /// <returns>受影响的行数</returns>

        public static int ExecuteNonQuery(string procedureName, SqlCommand comm)

        {

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                SetSqlCommand(comm, procedureName, conn, CommandType.StoredProcedure);

                return comm.ExecuteNonQuery();

            }

        }

        /// <summary>

        /// 执行存储过程,返回DataTable

        /// </summary>

        /// <param name="procedureName">存储过程名称</param>

        /// <param name="comm">Sqlcommand对象</param>

        /// <returns>DataTable</returns>

        public static DataTable ExecuteAdapter(string procedureName, SqlCommand comm)

        {

            DataTable dt = new DataTable();

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                SetSqlCommand(comm, procedureName, conn, CommandType.StoredProcedure);

                SqlDataAdapter adapter = new SqlDataAdapter(comm);

                adapter.Fill(dt);

            }

            return dt;

        }

        /// <summary>

        /// 使用事务执行多个非查询操作,sql语句不能相同

        /// </summary>

        /// <param name="sqlList">键:sql语句  值:参数集</param>

        /// <returns>是否全都成功执行</returns>

        public static bool ExecuteWithTransaction(Dictionary<string, List<SqlParameter>> sqlList)

        {

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                conn.Open();

                SqlTransaction tran = conn.BeginTransaction();

                SqlCommand comm = new SqlCommand();

                comm.Connection = conn;

                comm.Transaction = tran;

                try

                {

                    foreach (var v in sqlList)

                    {

                        comm.Parameters.Clear();

                        comm.CommandText = v.Key;

                        if (v.Value != null && v.Value.Count > )

                        {

                            comm.Parameters.AddRange(v.Value.ToArray());

                        }

                        comm.ExecuteNonQuery();

                    }

                    tran.Commit();

                    return true;

                }

                catch (Exception)

                {

                    tran.Rollback();

                    return false;

                }

            }

        }

        /// <summary>

        /// 使用事务执行多个非查询操作,通用

        /// </summary>

        /// <param name="sqlList">SQL对象</param>

        /// <returns>是否全都成功执行</returns>

        public static bool ExecuteWithTransaction(List<SQL> sqlList)

        {

            using (SqlConnection conn = new SqlConnection(conStr))

            {

                conn.Open();

                SqlTransaction tran = conn.BeginTransaction();

                SqlCommand comm = new SqlCommand();

                comm.Connection = conn;

                comm.Transaction = tran;

                try

                {

                    foreach (var v in sqlList)

                    {

                        comm.Parameters.Clear();

                        comm.CommandText = v.Sql;

                        if (v.ParameterList != null && v.ParameterList.Count > )

                        {

                            comm.Parameters.AddRange(v.ParameterList.ToArray());

                        }

                        comm.ExecuteNonQuery();

                    }

                    tran.Commit();

                    return true;

                }

                catch (Exception)

                {

                    tran.Rollback();

                    return false;

                }

            }

        }

    }

    /// <summary>

    /// SQL类,包含sql语句和参数集

    /// </summary>

    public class SQL

    {

        public string Sql { get; set; }

        public List<SqlParameter> ParameterList { get; set; }

        public SQL(string sql, List<SqlParameter> pars)

        {

            this.Sql = sql;

            this.ParameterList = pars;

        }

        public SQL(string sql)

        {

            this.Sql = sql;

        }

        public SQL()

        {

        }

    }

}

二.例子
    存储过程

alter proc p_getByGender

    @Gender char()=,

    @Count int output

as

    declare @CountSql nvarchar()

    set @CountSql='select @Count=count(1) from Student'

    exec sp_executesql @CountSql,N'@Count int output',@Count output

    declare @Sql nvarchar()

    set @Sql='select * from Student where Gender = '+CHAR()+@Gender+CHAR()

    print @Gender

    print @Sql

    exec(@Sql)

go

ADO.net调用

        //创建SqlCommand对象

                SqlCommand comm = new SqlCommand();

                //设置存储过程的参数

                comm.Parameters.Add("@Count", SqlDbType.Int).Direction = ParameterDirection.Output;

                comm.Parameters.Add("@Gender", SqlDbType.Char, ).Value = ;

                //调用DBHelper的方法返回结果

                DataTable dt=DBHelper.ExecuteAdapter("p_getByGender", comm);

                //储存过程的输出参数

                int count = (int)comm.Parameters["@Count"].Value; 

ADO.NET帮助类DBHelper的更多相关文章

  1. ADO.NET sqlHelper类(DBHelper类)

    1.配置文件 <connectionStrings> <add name="constr" connectionString="Data Source= ...

  2. 我也来写:数据库访问类DBHelper

    一.前言 相信许多人都百度过:“.net 数据库访问类”.然后就出来一大堆SqlHelper.我也用过这些SqlHelper,也自己写过,一堆静态方法,开始使用起来感觉很不错,它们也确实在很多时候可以 ...

  3. 我也来写:数据库访问类DBHelper(转)

    一.前言 相信许多人都百度过:“.net 数据库访问类”.然后就出来一大堆SqlHelper.我也用过这些SqlHelper,也自己写过,一堆静态方法,开始使用起来感觉很不错,它们也确实在很多时候可以 ...

  4. C#.NET数据库访问类DBHelper

    这是一个与C# .NET通用的数据库访问类,包含了工厂模式.事务处理等安全机制. 调用方式: DBHelper db = new DBHelper(); DbCommand cmd = db.GetS ...

  5. 通用数据库帮助类DBHelper(含log日志信息实时记录)

    项目需要,需要一个通用的数据库操作类,增删改查.事务.存储过程.日志记录都要有,于是在已有的帮助类上做了一些改进,并将log4j的.NET版--log4net嵌入其中记录sql的执行环境和状态. 用起 ...

  6. 数据帮助类DBhelper的定义

    数据库帮助类的使用DBhelperusing System;using System.Collections.Generic;using System.Text;using System.Data;u ...

  7. 数据库助手类 DBHelper

    using System; using System.Collections.Generic; using System.Text; using System.Configuration; using ...

  8. ado.net 实体类_数据访问类

    实体类: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ...

  9. ADO.NET 实体类和数据访问类

    SQL数据库字符串注入攻击:需要使用cmd.Parameters这个集合占位符: @key 代表这个位置用这个占位符占住了 Parameters这个集合中将此占位符所代表的数据补全 cmd.Param ...

随机推荐

  1. PHP使用curl伪造IP地址和header信息

    curl虽然功能强大,但是只能伪造$_SERVER["HTTP_X_FORWARDED_FOR"],对于大多数IP地址检测程序来说,$_SERVER["REMOTE_AD ...

  2. python计算机视觉2:图像边缘检测

    我是一名初学者,如果你发现文中有错误,请留言告诉我,谢谢 如果需要检测到图像里面的边缘,首先我们需要知道边缘处具有什么特征. 对于一幅灰度图像来说,边缘两边的灰度值肯定不相同,这样我们才能分辨出哪里是 ...

  3. Taurus.MVC

    开源:Taurus.MVC 框架 为什么要创造Taurus.MVC: 记得被上一家公司忽悠去负责公司电商平台的时候,情况是这样的: 项目原版是外包给第三方的,使用:WebForm+NHibernate ...

  4. sql helper

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.C ...

  5. "windows 正在启动"

    xp 在cmd下使用了control userpasswords2 设定开机不需要密码之后,开机停留在“window正在启动”,无法进入.估计是设置的时候密码输入错误了( 并不会提示你错误:() 在停 ...

  6. Bitmap 与ImageSource之间的转换

    public class ImageConverter { [DllImport("gdi32.dll", SetLastError = true)] private static ...

  7. 从Qt4到Qt5的,主要的进化有三(对于QtWidget的精简和优化会很有限)

    从Qt4到Qt5的,主要的进化有三:1 语言的进化,原来是基于C++(qtwidget)和XML(.ui),现在添加了QML(QtQuick)+JS(v8)的架构.2 绘图系统的进化,原先基于QPai ...

  8. QTableView中嵌入复选框CheckBox 的四种方法总结

    搜索了一下,QTableView中嵌入复选框CheckBox方法有四种: 第一种不能之前显示,必须双击/选中后才能显示,不适用. 第二种比较简单,通常用这种方法. 第三种只适合静态显示静态数据用 第四 ...

  9. Linux系统编程(9)—— 进程之进程控制函数exec系列函数

    在Linux中,并不存在exec()函数,exec指的是一组函数,一共有6个,分别是: #include <unistd.h> extern char **environ; int exe ...

  10. spring-boot+nginx+tomcat+ssl配置笔记

    如果你的tomcat应用需要采用ssl来加强安全性,一种做法是把tomcat配置为支持ssl,另一种做法是用nginx反向代理tomcat,然后把nginx配置为https访问,并且nginx与tom ...