ADO.NET帮助类DBHelper
一. 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的更多相关文章
- ADO.NET sqlHelper类(DBHelper类)
1.配置文件 <connectionStrings> <add name="constr" connectionString="Data Source= ...
- 我也来写:数据库访问类DBHelper
一.前言 相信许多人都百度过:“.net 数据库访问类”.然后就出来一大堆SqlHelper.我也用过这些SqlHelper,也自己写过,一堆静态方法,开始使用起来感觉很不错,它们也确实在很多时候可以 ...
- 我也来写:数据库访问类DBHelper(转)
一.前言 相信许多人都百度过:“.net 数据库访问类”.然后就出来一大堆SqlHelper.我也用过这些SqlHelper,也自己写过,一堆静态方法,开始使用起来感觉很不错,它们也确实在很多时候可以 ...
- C#.NET数据库访问类DBHelper
这是一个与C# .NET通用的数据库访问类,包含了工厂模式.事务处理等安全机制. 调用方式: DBHelper db = new DBHelper(); DbCommand cmd = db.GetS ...
- 通用数据库帮助类DBHelper(含log日志信息实时记录)
项目需要,需要一个通用的数据库操作类,增删改查.事务.存储过程.日志记录都要有,于是在已有的帮助类上做了一些改进,并将log4j的.NET版--log4net嵌入其中记录sql的执行环境和状态. 用起 ...
- 数据帮助类DBhelper的定义
数据库帮助类的使用DBhelperusing System;using System.Collections.Generic;using System.Text;using System.Data;u ...
- 数据库助手类 DBHelper
using System; using System.Collections.Generic; using System.Text; using System.Configuration; using ...
- ado.net 实体类_数据访问类
实体类: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ...
- ADO.NET 实体类和数据访问类
SQL数据库字符串注入攻击:需要使用cmd.Parameters这个集合占位符: @key 代表这个位置用这个占位符占住了 Parameters这个集合中将此占位符所代表的数据补全 cmd.Param ...
随机推荐
- 伪静态规则写法RewriteRule-htaccess详细语法使用
一.正则表达式教程伪静态规则写法RewriteRule-htaccess详细语法使用教程分享简单说下:伪静态实际上是利用PHP把当前地址解析成另外一种方法进行访问网站!要学伪静态规则的写法,你必须得懂 ...
- 【转】iOS代码规范
原文地址: http://www.cocoachina.com/ios/20150908/13335.html 简介: 本 文整理自Apple文档<Coding Guidelines for C ...
- 开心菜鸟系列学习笔记------javascript(4)
一.全局上下文中的变量对象: 1)全局对象(Global object) 是在进入任何执行上下文之前就已经创建了的对象:这个对象只存在一份,它的属性在程序中任何地方都可以访问,全局对象的 ...
- javascript之对象
一.创建对象 1.对象直接量. var point = { x:0,y:0 }; //point就是一个对象,跟C#不同,它不需要一定有类才能创建对象. 2.通过new创建对象 var d = new ...
- File类与FileInfo类
File是一个静态类,常用于文件操作,读取,修改文件等等.File类的大部分方法最终都是转换为流(Stream)的操作,只不过是.net提取帮你封装好了这些常用的流.并且会自动清理占用的资源. 例如: ...
- Oracle 唯一主键引发的行锁
SQL> create table test(id int PRIMARY KEY, name char(10)); 表已创建. Session 1: SQL> select * from ...
- MSSQL WITH (NOLOCK) 脏读
缺点: 1.会产生脏读 2.只适用与select查询语句 优点: 1.有些文件说,加了WITH (NOLOCK)的SQL查询效率可以增加33%. 2.可以用于inner join 语句 脏读: 一个用 ...
- location.href IE6 下不起作用的罪魁祸首
解决问题 在btn_publish函数内逻辑最后面加:return false;
- hdu 2896 病毒侵袭_ac自动机
题意:略 思路:套用ac自动机模板 #include <iostream> #include<cstdio> #include<cstring> using nam ...
- hdu 4619 Warm up 2 ( 二分图最大匹配 )
题目:Warm up 2 题意:有横竖两种方式放着的多米诺骨牌,相同方向的不可能重叠,但是横放和竖放 的牌可能重叠.移走重叠的牌使剩下的牌最多. 分析:二分图匹配:最大独立集= ...