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 ...
随机推荐
- ZendFramework2 源码分析 index.php
<?php /** * This makes our life easier when dealing with paths. Everything is relative * to the a ...
- Android应用开发中Intent的作用及使用方法
Intent是一种运行时绑定(run-time binding)机制,它能在程序运行过程中连接两个不同的组件.通过Intent,你的程序可以向Android表达某种请求或者意愿,Android会根据意 ...
- TENX_ASM.uew
/L14"TENX ASM" Nocase Line Comment = ; File Extensions = INC ASM LST H /Colors = ,,,,, /Co ...
- 开源欣赏wordpress之文章新增页面如何实现。
本地网址http://localhost/wordpress/wp-admin/post-new.php 进而找到post-new.php页面. 进入之后, require_once( dirname ...
- 【转】如何设置无线路由器的信道以获得最佳WIFI体验?
原文网址:http://jingyan.baidu.com/album/f25ef2546e28e4482c1b8225.html 现在随着移动互联网的发展,移动终端的普及,WIFI越来越必不可少,所 ...
- 诺基亚HERE地图
1.基本图层 2.3D图层 3.卫星图层 4.地形图层 5.在线帮助
- 运用 BoxLayout 进行 Swing 控件布局
摘自http://www.cnblogs.com/fnlingnzb-learner/p/6008572.html 运用 BoxLayout 进行 Swing 控件布局 对于初学 Java Swing ...
- Unity 图片分割将spirte保存在本地
如果你拿到的是一张整图,你想分割之后使用NGUI sprite来使用! 下面就能解决的需求. 步骤: 1. 使用Unity自带的spirte进行分割图片 2. 使用代码把分割出来的2DSpirte转 ...
- Android学习总结——SQLite
SQLiteDatabase类: 一.使用sql语句操作数据库 SQLiteDatabase db = openOrCreateDatabase("database.db", MO ...
- ubuntu 步步为营之uclinux编译和移植(完整版)
本节主要包含(ubuntu10.04) 一,linux下的经常使用压缩解压缩命令 二,环境建立 三,内核编译 四,移植 一,linux下的经常使用压缩解压缩命令 在linux下常见的压缩文件格式有ta ...