其中的部分内容是别人的,我修改过了并加入了详细的注释!!!

一、这个DBHelper的大致块儿如下图:

二、下面是具体的源代码:

//命名空间。。。。。

using System;
using System.Data;
using System.Data.Common;
using System.Configuration;

namespace Common
{
   public class DBHelper
  {

//属性区。。。。。
     private static string dbProviderName = ConfigurationManager.AppSettings["DbHelperProvider"];
     private static string dbConnectionString = ConfigurationManager.AppSettings["Connstr"];//我的数据库连接字符串,其名称是:Connstr
     private DbConnection connection;

//不带参数构造器。(暴露出去方便调用)
public DBHelper()
{
this.connection = CreateConnection(DBHelper.dbConnectionString);//创建连接
}
//带参数构造器。(暴露出去方便调用)
public DBHelper(string connectionString)
{
this.connection = CreateConnection(connectionString);//创建连接
}
/****************************************************< 直接连接 >***********************************************************/
public static DbConnection CreateConnection()

{
DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DBHelper.dbProviderName);
DbConnection dbconn = dbfactory.CreateConnection();
dbconn.ConnectionString = DBHelper.dbConnectionString;
return dbconn;
}

/****************************************************< 带连接字符串的连接 >************************************/
public static DbConnection CreateConnection(string connectionString)

{
     DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DBHelper.dbProviderName);
     DbConnection dbconn = dbfactory.CreateConnection();
     dbconn.ConnectionString = connectionString;
     return dbconn;
}

/****************************************************< 获取储存过程 >******************************************/
public DbCommand GetStoredProcCommond(string storedProcedure)

{
     DbCommand dbCommand = connection.CreateCommand();
     dbCommand.CommandText = storedProcedure;
     dbCommand.CommandType = CommandType.StoredProcedure;
     return dbCommand;
}

/****************************************************< 获取SQL语句命令 >**************************************/
public DbCommand GetSqlStringCommond(string sqlQuery)

{
    DbCommand dbCommand = connection.CreateCommand();
    dbCommand.CommandText = sqlQuery;
    dbCommand.CommandType = CommandType.Text;
    return dbCommand;
}

#region =======================================《 增加参数集合 》=============================
public void AddParameterCollection(DbCommand cmd, DbParameterCollection dbParameterCollection)
{
    foreach (DbParameter dbParameter in dbParameterCollection)//foreach(数据类型 标识符 in 表达式)
   {
       cmd.Parameters.Add(dbParameter);//增加参数
    }
}

/****************************************************< 增加输出参数 >*******************************************/
public void AddOutParameter(DbCommand cmd, string parameterName, DbType dbType, int size)

{
      DbParameter dbParameter = cmd.CreateParameter();
      dbParameter.DbType = dbType;
      dbParameter.ParameterName = parameterName;
      dbParameter.Size = size;
      dbParameter.Direction = ParameterDirection.Output;
      cmd.Parameters.Add(dbParameter);
}

/****************************************************< 增加输入参数 >********************************************/
public void AddInParameter(DbCommand cmd, string parameterName, DbType dbType, object value)

{
      DbParameter dbParameter = cmd.CreateParameter();
      dbParameter.DbType = dbType;
      dbParameter.ParameterName = parameterName;
      dbParameter.Value = value;
      dbParameter.Direction = ParameterDirection.Input;
      cmd.Parameters.Add(dbParameter);
}

/****************************************************< 增加返回输入参数 >****************************************/
public void AddReturnParameter(DbCommand cmd, string parameterName, DbType dbType)

{
    DbParameter dbParameter = cmd.CreateParameter();
    dbParameter.DbType = dbType;
    dbParameter.ParameterName = parameterName;
    dbParameter.Direction = ParameterDirection.ReturnValue;
    cmd.Parameters.Add(dbParameter);
}

/****************************************************< 获取参数 >*********************************************/
public DbParameter GetParameter(DbCommand cmd, string parameterName)
{
    return cmd.Parameters[parameterName];
}
#endregion

#region========================================《 普通执行 》============================
public DataSet ExecuteDataSet(DbCommand cmd)
{
    DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DBHelper.dbProviderName);
    DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();
    dbDataAdapter.SelectCommand = cmd;
    DataSet ds = new DataSet();
   dbDataAdapter.Fill(ds);
   return ds;
}

/****************************************************< 执行DataTable >******************************************/
public DataTable ExecuteDataTable(DbCommand cmd)
{
    DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DBHelper.dbProviderName);
    DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();
    dbDataAdapter.SelectCommand = cmd;
    DataTable dataTable = new DataTable();
    dbDataAdapter.Fill(dataTable);
    return dataTable;
}

/****************************************************< 执行Reader >********************************************/
public DbDataReader ExecuteReader(DbCommand cmd)
{
    cmd.Connection.Open();
    DbDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
    return reader;
}

/****************************************************< 执行SQL语句,并返回受到这条语句而改变的列 >*******************/
public int ExecuteNonQuery(DbCommand cmd)
{
    cmd.Connection.Open();
    int ret = cmd.ExecuteNonQuery();
    cmd.Connection.Close();
    return ret;
}

/*******************************< 执行SQL语句,从数据库中检索单个值返回值是object类型 >**************************/
public object ExecuteScalar(DbCommand cmd)
{
   cmd.Connection.Open();
   object ret = cmd.ExecuteScalar();
   cmd.Connection.Close();
   return ret;
}
#endregion

#region=====================================《 带事务的执行 》===============================
/****************************************************< 执行DataSet事务 >******************************************/
public DataSet ExecuteDataSet(DbCommand cmd,Trans t)
{
    cmd.Connection = t.DbConnection;
    cmd.Transaction = t.DbTrans;
    DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DBHelper.dbProviderName);
    DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();
    dbDataAdapter.SelectCommand = cmd;
    DataSet ds = new DataSet();
    dbDataAdapter.Fill(ds);
    return ds;
}

/****************************************************< 执行DataTable事务 >*****************************************/
public DataTable ExecuteDataTable(DbCommand cmd, Trans t)
{
    cmd.Connection = t.DbConnection;
    cmd.Transaction = t.DbTrans;
    DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DBHelper.dbProviderName);
    DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();
    dbDataAdapter.SelectCommand = cmd;
    DataTable dataTable = new DataTable();
    dbDataAdapter.Fill(dataTable);
    return dataTable;
}

/****************************************************< 执行Reader事务 >********************************************/
public DbDataReader ExecuteReader(DbCommand cmd, Trans t)
{
      cmd.Connection.Close();
      cmd.Connection = t.DbConnection;
      cmd.Transaction = t.DbTrans;
      DbDataReader reader = cmd.ExecuteReader();
      DataTable dt = new DataTable();
      return reader;
}

/****************************************************< ExecuteNonQuery >******************************************/
public int ExecuteNonQuery(DbCommand cmd, Trans t)
{
     cmd.Connection.Close();
     cmd.Connection = t.DbConnection;
     cmd.Transaction = t.DbTrans;
     int ret = cmd.ExecuteNonQuery();
     return ret;
}

/****************************************************< ExecuteScalar >*********************************************/
public object ExecuteScalar(DbCommand cmd, Trans t)
{
    cmd.Connection.Close();
    cmd.Connection = t.DbConnection;
    cmd.Transaction = t.DbTrans;
    object ret = cmd.ExecuteScalar();
    return ret;
}
#endregion
}

#region=================================================《 事务 》================================
public class Trans : IDisposable //IDisposable 接口:定义一种释放分配的非托管资源的方法
{
   private DbConnection conn;//连接
   private DbTransaction dbTrans;//事务

public DbConnection DbConnection
{
    get { return this.conn; }
}

public DbTransaction DbTrans
{
    get { return this.dbTrans; }
}

public Trans()
{
   conn = DBHelper.CreateConnection();
   conn.Open();
   dbTrans = conn.BeginTransaction();
}

public Trans(string connectionString)
{
   conn = DBHelper.CreateConnection(connectionString);
   conn.Open();
   dbTrans = conn.BeginTransaction();
}

public void Commit()//commit操作
{
    dbTrans.Commit();
    this.Colse();
}

public void RollBack()//RollBack操作
{
    dbTrans.Rollback();
    this.Colse();
}

public void Dispose()
{
    this.Colse();
}

public void Colse()
{
    if (conn.State == System.Data.ConnectionState.Open)
{
    conn.Close();
}
}
}
#endregion
}

三、数据库连接字符串

四、使用DBHelper的Demo

    

1、直接执行sql语句

        DbHelper db = new DbHelper();
        DbCommand cmd = db.GetSqlStringCommond("insert t1 (id)values('haha')");
        db.ExecuteNonQuery(cmd);

2、执行存储过程

        DbHelper db = new DbHelper();
        DbCommand cmd = db.GetStoredProcCommond("t1_insert");
        db.AddInParameter(cmd, "@id", DbType.String, "heihei");
        db.ExecuteNonQuery(cmd);

3、返回DataSet

        DbHelper db = new DbHelper();
        DbCommand cmd = db.GetSqlStringCommond("select * from t1");
        DataSet ds = db.ExecuteDataSet(cmd);

4、返回DataTable

        DbHelper db = new DbHelper();
        DbCommand cmd = db.GetSqlStringCommond("t1_findall");
        DataTable dt = db.ExecuteDataTable(cmd);

5、输入参数/输出参数/返回值的使用(比较重要哦)

        DbHelper db = new DbHelper();
        DbCommand cmd = db.GetStoredProcCommond("t2_insert");
        db.AddInParameter(cmd, "@timeticks", DbType.Int64, DateTime.Now.Ticks);
        db.AddOutParameter(cmd, "@outString", DbType.String, 20);
        db.AddReturnParameter(cmd, "@returnValue", DbType.Int32);

        db.ExecuteNonQuery(cmd);

       string s = db.GetParameter(cmd, "@outString").Value as string;//out parameter
      int r = Convert.ToInt32(db.GetParameter(cmd, "@returnValue").Value);//return value

6)DataReader使用

      DbHelper db = new DbHelper();
        DbCommand cmd = db.GetStoredProcCommond("t2_insert");
        db.AddInParameter(cmd, "@timeticks", DbType.Int64, DateTime.Now.Ticks);
        db.AddOutParameter(cmd, "@outString", DbType.String, 20);
        db.AddReturnParameter(cmd, "@returnValue", DbType.Int32);

 using (DbDataReader reader = db.ExecuteReader(cmd))
 {//该处克添加您需要的代码。。。
            dt.Load(reader);
        }
 string s = db.GetParameter(cmd, "@outString").Value as string;//out parameter
 int r = Convert.ToInt32(db.GetParameter(cmd, "@returnValue").Value);//return value

7、事务的使用.(项目中需要将基本的数据库操作组合成一个完整的业务流时,代码级的事务是必不可少的哦)

    pubic void DoBusiness()
 {
 using (Trans t = new Trans())
 {
 try
 {
                D1(t);
 throw new Exception();//如果有异常,会回滚滴
                D2(t);
                t.Commit();
            }
 catch
 {
                t.RollBack();
            }
        }
    }
 public void D1(Trans t)
 {
        DbHelper db = new DbHelper();
        DbCommand cmd = db.GetStoredProcCommond("t2_insert");
        db.AddInParameter(cmd, "@timeticks", DbType.Int64, DateTime.Now.Ticks);
        db.AddOutParameter(cmd, "@outString", DbType.String, 20);
        db.AddReturnParameter(cmd, "@returnValue", DbType.Int32);

 if (t == null) db.ExecuteNonQuery(cmd);
 else db.ExecuteNonQuery(cmd,t);
string s = db.GetParameter(cmd, "@outString").Value as string;//out parameter
 int r = Convert.ToInt32(db.GetParameter(cmd, "@returnValue").Value);//return value
    }
 public void D2(Trans t)
 {
        DbHelper db = new DbHelper();
        DbCommand cmd = db.GetSqlStringCommond("insert t1 (id)values('..')");        
 if (t == null) db.ExecuteNonQuery(cmd);
 else db.ExecuteNonQuery(cmd, t);
    }

五、我不造程序,我只是程序搬运工!!!

我的C# - Web - DAL- DBHelper.cs的更多相关文章

  1. System.Web.Mvc.HttpGetAttribute.cs

    ylbtech-System.Web.Mvc.HttpGetAttribute.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, P ...

  2. System.Web.Mvc.RouteAttribute.cs

    ylbtech-System.Web.Mvc.RouteAttribute.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, Pub ...

  3. System.Web.Mvc.HttpPostAttribute.cs

    ylbtech-System.Web.Mvc.HttpPostAttribute.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, ...

  4. System.Web.Mvc.RoutePrefixAttribute.cs

    ylbtech-System.Web.Mvc.RoutePrefixAttribute.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutra ...

  5. System.Web.Mvc.JavaScriptResult.cs

    ylbtech-System.Web.Mvc.JavaScriptResult.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, P ...

  6. System.Web.Mvc.ActionResult.cs

    ylbtech-System.Web.Mvc.ActionResult.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, Publi ...

  7. System.Web.Mvc.IAuthorizationFilter.cs

    ylbtech-System.Web.Mvc.IAuthorizationFilter.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutra ...

  8. System.Web.Mvc.IActionFilter.cs

    ylbtech-System.Web.Mvc.IActionFilter.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, Publ ...

  9. System.Web.Mvc.Controller.cs

    ylbtech-System.Web.Mvc.Controller.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, PublicK ...

  10. System.Web.Mvc.ControllerBase.cs

    ylbtech-System.Web.Mvc.ControllerBase.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, Pub ...

随机推荐

  1. python包管理-distutils,setuptools,pip,virtualenv等介绍

    python包管理-distutils,setuptools,pip,virtualenv等介绍 对于每个编程语言来说打包和发布开发包往往非常重要,而作为一个编程者能够快速容易的获得并应用这些由第三方 ...

  2. scanf(),fscanf的详解

    我们这里只讨论fscanf(或者scanf)的格式,因为这些细节在其他贴里并没有涉及,阅读此文,你可以少走一些弯路.只讲结果,深层原因并不分析. FILE *pFile:float x1; char ...

  3. android 一个页面内 多个listview的实现

    如果很平常的两个listview组件竖直放在linearLayout布局中,结果是: 两个listview 很独立,中间似乎有个分割线,完全吧他们分离了,各自独立滚动,如果上面的listview把整个 ...

  4. 【CF】270D Design Tutorial: Inverse the Problem

    题意异常的简单.就是给定一个邻接矩阵,让你判定是否为树.算法1:O(n^3).思路就是找到树边,原理是LCA.判断树边的数目是否为n-1.39-th个数据T了,自己测试2000跑到4s.算法2:O(n ...

  5. python换行写入文件

    今天用python做写入文件时,碰到,写入的东西不能换行,打开写入的文件都是一行.后来发现需要在写入的字符后面加上+'\n'. 另外python需要追加写入文件的时候,是用这个方法f = open(' ...

  6. 直接拿来用!最火的android开源项目(一)

    不好意思尊重一下作者咯.详情见:csdn:http://www.csdn.net/article/2013-05-03/2815127-Android-open-source-projects

  7. unity3d 制造自己的水体water effect(一)

    first,I wish you a happy new year, and study in spring festival’s eve means you are hardworking,haha ...

  8. Python中With的用法

    在看Dive Into Python中有关描述文件读写那章节的时候,看到了有关with的用法,查阅下相关资料,记录下来,以备后用. 官方的reference上有关with statement是这样说的 ...

  9. XML认识

    XML概念 XML是eXtensible Markup Langguage 缩写,称之为可扩展标记语言.XML 被设计用来传输和存储数据.与HTML不同的是: HTML被设计用来显示数据,其焦点是数据 ...

  10. ImageView类简介

    4.8  图片控件 本节将要介绍的是图片控件ImageView,首先对ImageView类进行简单介绍,然后通过一个案例来说明ImageView的用法. 4.8.1  ImageView类简介 Ima ...