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

namespace Lee.Data
{
    public class DataAccess
    {
        #region 字段 构造函数
        public readonly DbProviderFactory Factory;
        public readonly ConnectionStringSettings ConnectionSettings;

public static DataAccess Instance = new DataAccess();

DataAccess() {
            this.ConnectionSettings = ConfigurationManager.ConnectionStrings["default"];
            this.Factory = DbProviderFactories.GetFactory(this.ConnectionSettings.ProviderName);
        }
        #endregion

#region 创建 DbConnection, DbCommand对象
        /// <summary>
        /// 获取一个新的DbConnection对象
        /// </summary>
        /// <returns>DbConnection</returns>
        public DbConnection CreateConnection() {
            DbConnection connection = Factory.CreateConnection();
            connection.ConnectionString = this.ConnectionSettings.ConnectionString;
            return connection;
        }

/// <summary>
        /// 使用sql语句创建一个DbCommand对象
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <returns></returns>
        public DbCommand CreateCommand(String sql) {
            return this.CreateCommand(sql, CommandType.Text, null, this.CreateConnection());
        }

/// <summary>
        /// 使用sql语句,DbConnection对象创建一个DbCommand对象
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <param name="connection">DbConnection对象</param>
        /// <returns></returns>
        public DbCommand CreateCommand(String sql, DbConnection connection) {
            return this.CreateCommand(sql, CommandType.Text, null, connection);
        }

/// <summary>
        /// 使用sql语句, CommandType, DbParameter数组 创建一个DbCommand对象
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <param name="type">DbCommand所执行命令的类型</param>
        /// <param name="parameters">DbCommand的参数</param>
        /// <returns></returns>
        public DbCommand CreateCommand(String sql, CommandType type, DbParameter[] parameters) {
            DbCommand cmd = Factory.CreateCommand();
            cmd.CommandType = type;
            cmd.CommandText = sql;
            cmd.Connection = this.CreateConnection();
            if(parameters != null && parameters.Length > 0)
                cmd.Parameters.AddRange(parameters);
            return cmd;
        }

/// <summary>
        /// 使用sql语句, CommandType, DbParameter数组, DbConnection对象 创建一个DbCommand对象
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <param name="type">DbCommand所执行命令的类型</param>
        /// <param name="parameters">DbCommand的参数</param>
        /// <param name="connection">connection对象</param>
        /// <returns></returns>
        public DbCommand CreateCommand(String sql, CommandType type, DbParameter[] parameters, DbConnection connection) {
            DbCommand cmd = null;
            if (connection == null) cmd = this.CreateConnection().CreateCommand();
            else cmd = connection.CreateCommand();
            cmd.CommandType = type;
            cmd.CommandText = sql;
            if (parameters != null && parameters.Length > 0)
                cmd.Parameters.AddRange(parameters);
            return cmd;
        }
        #endregion

#region 执行sql语句
        /// <summary>
        /// 执行sql语句返回受影响的行数
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <returns></returns>
        public int ExecuteNoneQuery(String sql) {
            using (DbConnection connection = this.CreateConnection()) {
                using (DbCommand command = connection.CreateCommand()) {
                    this.Open(connection);
                    command.CommandText = sql;
                    return command.ExecuteNonQuery();
                }
            }
        }

/// <summary>
        /// 使用指定的DbConnection对象执行sql语句并返回受影响的行数
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <param name="connection">DbConnection对象</param>
        /// <returns></returns>
        public int ExecuteNoneQuery(String sql, DbConnection connection) {
            using (DbCommand command = connection.CreateCommand()) {
                command.CommandText = sql;
                this.Open(connection);
                return command.ExecuteNonQuery();
            }
        }

/// <summary>
        /// 执行sql语句获取第一行第一列的值 (Object类型)
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <returns></returns>
        public Object ExecuteScalar(String sql) {
            using (DbConnection connection = this.CreateConnection()) {
                using (DbCommand command = connection.CreateCommand()) {
                    command.CommandText = sql;
                    this.Open(connection);
                    return command.ExecuteScalar();
                }
            }
        }

/// <summary>
        /// 使用指定的DbConnection对象执行sql语句并获取第一行第一列的值 (Object类型)
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <param name="connection">DbConnection对象</param>
        /// <returns></returns>
        public Object ExecuteScalar(String sql, DbConnection connection) {
            using (DbCommand command = connection.CreateCommand()) {
                command.CommandText = sql;
                command.Connection = connection;
                this.Open(connection);
                return command.ExecuteScalar();
            }
        }

/// <summary>
        /// 执行sql语句获取第一行第一列的值 (int类型)
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <returns></returns>
        public Int32? ExecuteScalarGetInt(String sql) {
            Object obj =  this.ExecuteScalar(sql);
            return obj == null ? null : (Int32?)obj;
        }

/// <summary>
        /// 使用指定的DbConnection执行sql语句并获取第一行第一列的值 (int类型)
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <param name="connection">DbConnection对象</param>
        /// <returns></returns>
        public Int32? ExecuteScalarGetInt(String sql, DbConnection connection) {
            Object obj = this.ExecuteScalar(sql, connection);
            return obj == null ? null : (Int32?)obj;
        }

/// <summary>
        /// 执行sql语句并获取第一行第一列的值 (String类型)
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <returns></returns>
        public String ExcuteScalarGetString(String sql) {
            Object obj = this.ExecuteScalar(sql);
            return obj == null ? null : obj.ToString();
        }

/// <summary>
        /// 使用指定的DbConnection执行sql语句并获取第一行第一列的值 (String类型)
        /// </summary>
        /// <param name="sql">要执行的sql语句</param>
        /// <param name="connection">DbConnection对象</param>
        /// <returns></returns>
        public String ExcuteScalarGetString(String sql, DbConnection connection) {
            Object obj = this.ExecuteScalar(sql, connection);
            return obj == null ? null : obj.ToString();
        }

/// <summary>
        /// 使用指定的sql语句创建一个DbDataReader对象
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <returns></returns>
        public DbDataReader ExecuteReader(String sql) {
            DbConnection connection = this.CreateConnection();
            DbCommand command = connection.CreateCommand();
            command.CommandText = sql;
            this.Open(connection);
            return command.ExecuteReader(CommandBehavior.CloseConnection);
        }

/// <summary>
        /// 使用指定的DbConnection对象执行sql语句并获取一个DbDataReader对象
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <param name="connection">DbConnection对象</param>
        /// <returns></returns>
        public DbDataReader ExecuteReader(String sql, DbConnection connection) {
            DbCommand command = connection.CreateCommand();
            command.CommandText = sql;
            this.Open(connection);
            return command.ExecuteReader();
        }

/// <summary>
        /// 执行sql语句返回DataTable
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <returns></returns>
        public DataTable GetDataTable(String sql) {
            using (DbConnection connection = this.CreateConnection()) {
                using (DbDataAdapter adapter = Factory.CreateDataAdapter()) {
                    using (adapter.SelectCommand = connection.CreateCommand()) {
                        adapter.SelectCommand.CommandText = sql;
                        DataTable table = new DataTable();
                        adapter.Fill(table);
                        return table;
                    }
                }
            }
        }

/// <summary>
        /// 执行sql语句返回DataTable
        /// </summary>
        /// <param name="sql"></param>
        /// <param name="connection"></param>
        /// <returns></returns>
        public DataTable GetDataTable(String sql, DbConnection connection) {
            using (DbDataAdapter adapter = Factory.CreateDataAdapter()) {
                using (adapter.SelectCommand = connection.CreateCommand()) {
                    adapter.SelectCommand.CommandText = sql;
                    DataTable table = new DataTable();
                    adapter.Fill(table);
                    return table;
                }
            }
        }

#endregion

#region 执行存储过程
        public ArrayList ExecuteProc(String procName, DbParameter[] parameters) {
            DbCommand command = this.CreateCommand(procName, CommandType.StoredProcedure, parameters);
            ArrayList values = new ArrayList(parameters.Length / 2);
            try {
                this.Open(command);
                command.ExecuteNonQuery();
                foreach (DbParameter item in parameters)
                    if (item.Direction == ParameterDirection.Output)
                        values.Add(item.Value);
            }
            catch { throw; }
            finally { command.Connection.Dispose(); command.Dispose(); }
            return values;
        }

/// <summary>
        /// 执行存储过程并将输出参数作为int数组返回
        /// </summary>
        /// <param name="procName">存储过程名称</param>
        /// <param name="parameters">存储过程参数</param>
        /// <returns></returns>
        public Int32[] ExecuteProcGetInt(String procName, DbParameter[] parameters) {
            ArrayList values = this.ExecuteProc(procName, parameters);
            Int32[] intValues = new Int32[values.Count];
            for (int i = 0; i < values.Count; i++)
                intValues[i] = (Int32)values[i];
            return intValues;
        }

/// <summary>
        /// 执行存储过程并将输出参数作为String数组返回
        /// </summary>
        /// <param name="procName">存储过程名称</param>
        /// <param name="parameters">存储过程参数</param>
        /// <returns></returns>
        public String[] ExecuteProcGetString(String procName, DbParameter[] parameters) {
            ArrayList values = this.ExecuteProc(procName, parameters);
            String[] stringValues = new String[values.Count];
            for (int i = 0; i < values.Count; i++)
                stringValues[i] = values[i].ToString();
            return stringValues;
        }

/// <summary>
        /// 执行存储过程并获取一个DbDataReader对象
        /// </summary>
        /// <param name="procName">存储过程名称</param>
        /// <param name="parameters">存储过程参数</param>
        /// <returns></returns>
        public DbDataReader ExecuteProcGetDataReader(String procName, DbParameter[] parameters) {
            DbCommand command = this.CreateCommand(procName, CommandType.StoredProcedure, parameters);
            DbDataReader reader = null;
            try { this.Open(command); reader = command.ExecuteReader(CommandBehavior.CloseConnection); }
            catch { throw; }
            //finally { command.Connection.Dispose(); command.Dispose(); }
            return reader;
        }

/// <summary>
        /// 执行存储过程获取DataTable
        /// </summary>
        /// <param name="procName">存储过程名称</param>
        /// <param name="parameters">存储过程参数</param>
        /// <returns></returns>
        public DataTable ExecuteProcGetDataTable(String procName, DbParameter[] parameters) {
            DataTable table = new DataTable();
            DbDataAdapter adapter = null;

try {
                adapter = Factory.CreateDataAdapter();
                adapter.SelectCommand = this.CreateCommand(procName, CommandType.StoredProcedure, parameters);
                adapter.Fill(table);
            }
            catch { throw; }
            finally {
                adapter.SelectCommand.Connection.Dispose();
                adapter.SelectCommand.Dispose();
                adapter.Dispose();
            }
            return table;
        }

#endregion

#region 其它

/// <summary>
        /// 创建一个输入参数
        /// </summary>
        /// <param name="name"></param>
        /// <param name="value"></param>
        /// <returns></returns>
        public DbParameter CreateParameter(String name, Object value) {
            return this.CreateParameter(name, value, DbType.Object, ParameterDirection.Input);
        }

/// <summary>
        /// 创建一个输入参数
        /// </summary>
        /// <param name="name"></param>
        /// <param name="value"></param>
        /// <param name="type"></param>
        /// <returns></returns>
        public DbParameter CreateParameter(String name, Object value, DbType type) {
            return this.CreateParameter(name, value, type, ParameterDirection.Input);
        }

/// <summary>
        /// 创建一个输出参数
        /// </summary>
        /// <param name="name"></param>
        /// <returns></returns>
        public DbParameter CreateParameter(String name, DbType type) {
            DbParameter parameter = Factory.CreateParameter();
            parameter.ParameterName = name;
            parameter.Direction = ParameterDirection.Output;
            parameter.DbType = type;
            return parameter;
        }

public DbParameter CreateParameter(String name, Object value, DbType type, ParameterDirection direct) {
            DbParameter parameter = Factory.CreateParameter();
            parameter.ParameterName = name;
            parameter.Value = value;
            parameter.DbType = type;
            parameter.Direction = direct;
            return parameter;
        }

/// <summary>
        /// 打开连接
        /// </summary>
        /// <param name="connection">需要打开的DbConnection对象</param>
        public void Open(DbConnection connection) {
            if(connection.State != ConnectionState.Open)
                try { connection.Open(); }
                catch { throw; }
        }

/// <summary>
        /// 打开连接
        /// </summary>
        /// <param name="command">需要打开的DbCommand对象</param>
        public void Open(DbCommand command) {
            if (command.Connection.State == ConnectionState.Open)
                return;
            try { command.Connection.Open(); }
            catch { throw; }
        }
        #endregion
    }
}

DbHelper第三版, 数据库通吃的更多相关文章

  1. [Android 4.4.3] 泛泰A860 Omni4.4.3 20140610 RC2.0 三版通刷 by syhost

    欢迎关注泛泰非盈利专业第三方开发团队 VegaDevTeam  (本team 由 syhost suky zhaochengw(z大) xuefy(大星星) tenfar(R大师) loogeo cr ...

  2. 泛泰A870刷4.4专用英文版非触摸CWM Recovery 6.0.4.8(三版通刷)

    首先声明. 发此Recovery的目的是測试能否够三版都能够启动. 而且不会出现像850 860之前出现过的卡第一屏问题! 不希望看到某些人士的过度解读!! 此Recovery能够刷第三方4.4 RO ...

  3. JavaScript高级程序设计(第三版)学习笔记20、21、23章

    第20章,JSON JSON(JavaScript Object Notation,JavaScript对象表示法),是JavaScript的一个严格的子集. JSON可表示一下三种类型值: 简单值: ...

  4. 泛泰A870L/K/S第三版官方4.4.2原来的系统卡刷机包 (愿自己主动ROOT)

    采用suky大神ota具,来自官方的拍摄OTA包裹,未做任何改动, 使用官方recovery,还是我的头发中国TWRP 2.7.1.1 for A870 (己主动ROOT. 自己主动ROOT完后就自己 ...

  5. [Android 4.4.3] 泛泰A870 Mokee4.4.3 20140610 RC2.0 通过刷第三版 by syhost

    欢迎关注泛泰非盈利专业第三方开发团队 VegaDevTeam  (本team 由 syhost suky zhaochengw(z大) xuefy(大星星) tenfar(R大师) loogeo cr ...

  6. 【unix网络编程第三版】阅读笔记(三):基本套接字编程

    unp第三章主要介绍了基本套接字编程函数.主要有:socket(),bind(),connect(),accept(),listen()等. 本博文也直接进入正题,对这几个函数进行剖析和讲解. 1. ...

  7. 重读《学习JavaScript数据结构与算法-第三版》- 第5章 队列

    定场诗 马瘦毛长蹄子肥,儿子偷爹不算贼,瞎大爷娶个瞎大奶奶,老两口过了多半辈,谁也没看见谁! 前言 本章为重读<学习JavaScript数据结构与算法-第三版>的系列文章,主要讲述队列数据 ...

  8. 微软发布 Windows Server 2016 预览版第三版,开发者要重点关注Nano Server

    微软已经发布 Windows Server 2016 和 System Center 2016 第三个技术预览版,已经提供下载.Windows Server 2016 技术预览版第三版也是首个包括了容 ...

  9. 0038 Java学习笔记-多线程-传统线程间通信、Condition、阻塞队列、《疯狂Java讲义 第三版》进程间通信示例代码存在的一个问题

    调用同步锁的wait().notify().notifyAll()进行线程通信 看这个经典的存取款问题,要求两个线程存款,两个线程取款,账户里有余额的时候只能取款,没余额的时候只能存款,存取款金额相同 ...

随机推荐

  1. LR_问题_无法打开IE浏览器、监视服务器资源

    无法打开IE浏览器 使用web(http)协议录制时,无法打开IE浏览器,且生成的日志信息为 ****** Start Log Message ****** Web Recorder version ...

  2. ReadDirectoryChangesW 监控文件夹 (一个简单的监控示例程序)(文件被修改了,也可以探测到)

    // .h文件 #pragma once typedef void (*PFN_NotifyAction)(DWORD dwAction, LPWSTR szFile, DWORD dwLength) ...

  3. POJ1986 DistanceQueries 最近公共祖先LCA 离线算法Tarjan

    这道题与之前那两道模板题不同的是,路径有了权值,而且边是双向的,root已经给出来了,就是1,(这个地方如果还按之前那样来计算入度是会出错的.数据里会出现多个root...数据地址可以在poj的dis ...

  4. maven项目:Invalid bound statement

    在使用maven做mybatis项目时会遇到这个问题, org.apache.ibatis.binding.BindingException: Invalid bound statement (not ...

  5. 【原创】MySql 数据库导入导出(备份)

    啥不说了,两周前刚刚做过mysql导入导出的结果现在又忘了.. 更可悲的是竟然同样的三篇blog,现在看起来还是如当初一样费劲,里面的内容..所以自己写个记录一下 环境:*nix 权限:有相关表的写读 ...

  6. java.lang.NumberFormatException: For input string:"filesId"

    做项目时候,页面获取出现了这个问题.找了好久一直以为是我字段或者是数据库字段问题导致引起的. 最后才发现是 struts2中jsp我写错了一个参数,一直导致报错.后来改了就好了. 当大家遇到这个问题的 ...

  7. 你用哪种工具进行iOS app自动化功能测试?

    原文见http://www.cocoachina.com/applenews/devnews/2013/1111/7332.html

  8. 【转】JAVA之动态代理

    转自:像少年啦飞驰 代理设计模式 定义:为其他对象提供一种代理以控制对这个对象的访问. 代理模式的结构如下图所示. 动态代理使用 java动态代理机制以巧妙的方式实现了代理模式的设计理念. 代理模式示 ...

  9. 零基础学通C语言,福利来啦!!!!zfhl.ke.qq.com

  10. 【Java集合框架】规则集--Set

    集合: Java主要支持三种: 1.规则集(Set) 用于存储一组不重复的元素 2.线性表(List) 用于存储一个由元素构成的有序集合 3.队列(Queue) 同与数据结构中的队列,存储用先进先出的 ...