DbHelper类设计分析(2010070915)

来源:互联网 发布:2014年消费数据统计 编辑:程序博客网 时间:2024/05/17 06:21

本章目录
  1. ADO.NET数据库操作的类图
  2. DbHelper类结构分析
  3. ADO.NET数据库访问实例

1  ADO.NET数据库操作的类图

2  DbHelper类结构分析 代码下载

这里我给大家共享一个我参照企业库中的数据操作组件编码风格写的数据库操作类,对使用它的程序员来说,编码是很舒服滴(起码我觉得很好撒).以下是代码,很简单的,没有做任何多余的封装,只是改变了ADO.NET的编码步骤,方便了具体开发数据库操作代码的程序员.

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

   
public class DbHelper
   
{
       
private static string dbProviderName = ConfigurationManager.AppSettings["DbHelperProvider"];
       
private static string dbConnectionString = ConfigurationManager.AppSettings["DbHelperConnectionString"];

       
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;
        }

       
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)
           
{
                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;
        }


       
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;
        }


       
public DbDataReader ExecuteReader(DbCommand cmd)
       
{
            cmd.Connection.Open();
            DbDataReader reader
= cmd.ExecuteReader(CommandBehavior.CloseConnection);            
           
return reader;
        }

       
public int ExecuteNonQuery(DbCommand cmd)
       
{
            cmd.Connection.Open();
           
int ret = cmd.ExecuteNonQuery();
            cmd.Connection.Close();
           
return ret;
        }


       
public object ExecuteScalar(DbCommand cmd)
       
{
            cmd.Connection.Open();
           
object ret = cmd.ExecuteScalar();
            cmd.Connection.Close();
           
return ret;
        }

       
#endregion
       

       
#region 执行事务
       
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;
        }


       
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;
        }


       
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;
        }

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


       
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

    }


   
public class Trans : 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()
       
{
            dbTrans.Commit();
           
this.Colse();
        }


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


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


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

        }

    }

3  ADO.NET数据库访问实例 代码下载

原创粉丝点击