using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;
using System.Data.SqlClient;
using System.Data.OleDb;
using System.Data.OracleClient;
using System.Diagnostics;
using System.Configuration;
using System.Collections; namespace ManagerMent.DbHelper
{
public class DbHelper
{
#region 数据库连接字段(web.config来配置)
public string ConnectString { get; set; }
public string ConnectStringSql { get; set; }
public string ConnectStringOrl { get; set; } public DbHelper()
{
ConnectString = ConfigurationManager.AppSettings["ConnectionString"];
ConnectStringSql = ConfigurationManager.AppSettings["ConnectionSql"];
ConnectStringOrl = ConfigurationManager.AppSettings["ConnectStringOrl"]; }
#endregion #region 创建Connection
private IDbConnection GetConnection(string DbType)
{
switch (DbType)
{
case "SqlServer":
return new SqlConnection(ConnectStringSql);
case "Oracle":
return new OracleConnection(ConnectStringOrl);
case "Access":
return new OleDbConnection(ConnectString);
default:
return new SqlConnection(ConnectStringSql);
}
}
#endregion #region 创建Command
private IDbCommand GetCommand(string DbType, string sql, IDbConnection iConn)
{
switch (DbType)
{
case "SqlServer":
return new SqlCommand(sql, (SqlConnection)iConn);
case "Oracle":
return new OracleCommand(sql, (OracleConnection)iConn);
case "Access":
return new OleDbCommand(sql, (OleDbConnection)iConn);
default:
return new SqlCommand(sql, (SqlConnection)iConn);
}
}
private IDbCommand GetCommand(string DbType)
{
switch (DbType)
{
case "SqlServer":
return new SqlCommand();
case "Oracle":
return new OracleCommand();
case "Access":
return new OleDbCommand();
default:
return new SqlCommand();
}
}
#endregion #region 创建Adapter
private IDataAdapter GetAdapter(string DbType, string sql, IDbConnection iConn)
{
switch (DbType)
{
case "SqlServer":
return new SqlDataAdapter(sql, (SqlConnection)iConn);
case "Oracle":
return new OracleDataAdapter(sql, (OracleConnection)iConn);
case "Access":
return new OleDbDataAdapter(sql, (OleDbConnection)iConn);
default:
return new SqlDataAdapter(sql, (SqlConnection)iConn);
}
}
private IDataAdapter GetAdapter(string DbType, IDbCommand iCmd)
{
switch (DbType)
{
case "SqlServer":
return new SqlDataAdapter((SqlCommand)iCmd);
case "Oracle":
return new OracleDataAdapter((OracleCommand)iCmd);
case "Access":
return new OleDbDataAdapter((OleDbCommand)iCmd);
default:
return new SqlDataAdapter((SqlCommand)iCmd);
}
}
#endregion #region 执行数据库表操作
public IDataReader ExecuteReader(string DbType, string SqlString)
{
IDbConnection iConn = GetConnection(DbType);
{
iConn.Open();
IDbCommand iCmd = GetCommand(DbType);
{
try
{
PrepareCommand(DbType, out iCmd, iConn, null, SqlString, null);
IDataReader iReader = iCmd.ExecuteReader();
return iReader;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
iCmd.Dispose(); }
}
} } private void PrepareCommand(string DbType, out IDbCommand iCmd, IDbConnection iConn, IDbTransaction iTrans, string cmdText, IDataParameter[] iParms)
{
if (iConn.State != ConnectionState.Open)
{
iConn.Open();
}
iCmd = GetCommand(DbType);
iCmd.Connection = iConn;
iCmd.CommandText = cmdText;
if (iTrans != null)
{
iCmd.Transaction = iTrans;
}
iCmd.CommandType = CommandType.Text; //cmdType
if (iParms != null)
{
foreach (IDataParameter parm in iParms)
{
iCmd.Parameters.Add(parm);
}
} } //执行查询语句,返回DataSet,重点用于Oracle数据库
public DataSet Query(string DbType, string SqlString)
{
using (IDbConnection iConn = GetConnection(DbType))
{
DataSet Ds = new DataSet();
iConn.Open();
try
{
IDataAdapter iAdapter = GetAdapter(DbType, SqlString, iConn);
iAdapter.Fill(Ds);
return Ds;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
if (iConn.State != ConnectionState.Closed)
{
iConn.Close();
}
}
}
} //执行查询语句,返回DataTable,重点用于Oracle数据库
public DataTable ExcuteQuery(string DbType, string SqlString)
{
using (IDbConnection iConn = GetConnection(DbType))
{
DataSet Ds = new DataSet();
iConn.Open();
try
{
IDataAdapter iAdapter = GetAdapter(DbType, SqlString, iConn);
iAdapter.Fill(Ds);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
if (iConn.State != ConnectionState.Closed)
{
iConn.Close();
}
}
return Ds.Tables[];
}
} //执行数据库表操作,重点用于SqlServer数据库
public void ExcuteSqlScalar(string DbType, string SqlString)
{
using (IDbConnection iConn = GetConnection(DbType))
{
using (IDbCommand iCmd = GetCommand(DbType, SqlString, iConn))
{
iConn.Open();
iCmd.ExecuteNonQuery();
}
}
} public int ExcuteSqlNum(string DbType, string SqlString)
{
using (IDbConnection iConn = GetConnection(DbType))
{
using (IDbCommand iCmd = GetCommand(DbType, SqlString, iConn))
{
iConn.Open();
int i = (int)iCmd.ExecuteScalar();
return i;
}
}
} public bool ExcuteSql(string DbType, string SqlString)
{
using (IDbConnection iConn = GetConnection(DbType))
{
using (IDbCommand iCmd = GetCommand(DbType, SqlString, iConn))
{
iConn.Open();
try
{
int Rows = (int)iCmd.ExecuteScalar();
return false;
}
catch (Exception ex)
{
return true;
}
finally
{
if (iConn.State != ConnectionState.Closed)
{
iConn.Close();
}
}
} }
} //删除数据
public void DeleGet(string DbType, string SqlString)
{
using (IDbConnection iConn = GetConnection(DbType))
{
using (IDbCommand iCmd = GetCommand(DbType, SqlString, iConn))
{
iConn.Open();
iCmd.ExecuteNonQuery();
}
}
}
#endregion #region 执行多条SQL语句,实现数据库事物
/// <summary>
///
/// </summary>
/// <param name="DbType"></param>
/// <param name="SqlStringList">多条SQL语句</param>
/// <returns></returns>
public bool ExcuteSqlTran(string DbType, ArrayList SqlStringList)
{
using (IDbConnection iConn = GetConnection(DbType))
{
iConn.Open();
using (IDbCommand iCmd = GetCommand(DbType))
{
iCmd.Connection = iConn;
using (IDbTransaction iDbTran = iConn.BeginTransaction())
{
iCmd.Transaction = iDbTran;
try
{
for (int n = ; n < SqlStringList.Count; n++)
{
string StrSql = SqlStringList[n].ToString();
if (StrSql.Trim().Length > )
{
iCmd.CommandText = StrSql;
iCmd.ExecuteNonQuery();
}
}
iDbTran.Commit();
}
catch (Exception ex)
{
Debug.WriteLine("ExcuteSqlTran" + ex.Message);
iDbTran.Rollback();
return false;
}
finally
{
if (iConn.State != ConnectionState.Closed)
{
iConn.Close();
}
}
}
}
return true;
}
} #endregion #region SQL数据库解析格式
private IDbDataParameter DbPara(string DbType, string ParaName, string DataType)
{
switch (DbType)
{
case "SqlServer":
return GetSqlPara(ParaName, DataType);
case "Oracle":
return GetOraclePara(ParaName, DbType);
case "Access":
return GetOledbPara(ParaName, DbType);
default:
return GetSqlPara(ParaName, DbType);
}
} private IDbDataParameter GetSqlPara(string ParaName, string DataType)
{
switch (DataType)
{
case "Decimal":
return new SqlParameter(ParaName, SqlDbType.Decimal);
case "VarChar":
return new SqlParameter(ParaName, SqlDbType.VarChar);
case "DateTime":
return new SqlParameter(ParaName, SqlDbType.DateTime);
case "Image":
return new SqlParameter(ParaName, SqlDbType.Image);
case "Int":
return new SqlParameter(ParaName, SqlDbType.Int);
case "Text":
return new SqlParameter(ParaName, SqlDbType.Text);
default:
return new SqlParameter(ParaName, SqlDbType.VarChar);
}
} //Oracle数据库解析数据格式
private IDbDataParameter GetOraclePara(string ParaName, string DbType)
{
switch (DbType)
{
case "Decimal":
return new OracleParameter(ParaName, SqlDbType.Decimal);
case "VarChar":
return new OracleParameter(ParaName, SqlDbType.VarChar);
case "DateTime":
return new OracleParameter(ParaName, SqlDbType.DateTime);
case "Image":
return new OracleParameter(ParaName, SqlDbType.Image);
case "Int":
return new OracleParameter(ParaName, SqlDbType.Int);
case "Text":
return new OracleParameter(ParaName, SqlDbType.Text);
default:
return new OracleParameter(ParaName, SqlDbType.VarChar);
}
} //Access(OLEDB)数据库数据解析格式
private IDbDataParameter GetOledbPara(string ParaName, string DbType)
{
switch (DbType)
{
case "Decimal":
return new OleDbParameter(ParaName, SqlDbType.Decimal);
case "VarChar":
return new OleDbParameter(ParaName, SqlDbType.VarChar);
case "DateTime":
return new OleDbParameter(ParaName, SqlDbType.DateTime);
case "Image":
return new OleDbParameter(ParaName, SqlDbType.Image);
case "Int":
return new OleDbParameter(ParaName, SqlDbType.Int);
case "Text":
return new OleDbParameter(ParaName, SqlDbType.Text);
default:
return new OleDbParameter(ParaName, SqlDbType.VarChar);
}
} #endregion #region 执行存储过程
public DataSet RunProcedure(string DbType, string StoreProcName, IDataParameter[] Parameters, DataSet dataSet, string TableName)
{
using (IDbConnection iConn = GetConnection(DbType))
{
iConn.Open();
IDataAdapter iDa = GetAdapter1(DbType, BuildQueryCommand(DbType, iConn, StoreProcName, Parameters));
((SqlDataAdapter)iDa).Fill(dataSet, TableName);
if(iConn.State!=ConnectionState.Closed)
{
iConn.Close();
}
return dataSet;
}
} private IDbCommand BuildQueryCommand(string dbType, IDbConnection iConn, string storeProcName, IDataParameter[] parameters)
{
IDbCommand iCmd = GetCommand(dbType,storeProcName,iConn);
iCmd.CommandType = CommandType.StoredProcedure;
if(parameters==null)
{
return iCmd;
}
foreach(IDataParameter parameter in parameters)
{
iCmd.Parameters.Add(parameter);
}
return iCmd;
} private IDataAdapter GetAdapter1(string DbType, IDbCommand iCmd)
{
switch(DbType)
{
case "SqlServer":
return new SqlDataAdapter((SqlCommand)iCmd);
case "Oracle":
return new OracleDataAdapter((OracleCommand)iCmd);
case "Oledb":
return new OleDbDataAdapter((OleDbCommand)iCmd);
default:
return new SqlDataAdapter((SqlCommand)iCmd);
}
} /// <summary>
/// 执行存储过程
/// </summary>
/// <param name="DbType"></param>
/// <param name="storeProcName"></param>
/// <param name="parameters"></param>
/// <param name="TableName"></param>
/// <returns></returns>
public DataSet RunProcedure(string DbType,string storeProcName,IDbDataParameter[] parameters,string TableName)
{
using (IDbConnection iConn=GetConnection(DbType))
{
DataSet Ds = new DataSet();
iConn.Open();
IDataAdapter iDa = GetAdapter(DbType,BuildQueryCommand(DbType,iConn,storeProcName,parameters));
((SqlDataAdapter)iDa).Fill(Ds,TableName);
if(iConn.State!=ConnectionState.Closed)
{
iConn.Close();
}
return Ds;
}
} public DataSet RunProcedure(string DbType,string storeProcName,IDbDataParameter[] parameters)
{
using (IDbConnection iConn=GetConnection(DbType))
{
DataSet Ds = new DataSet();
IDataAdapter iDa = GetAdapter(DbType,BuildQueryCommand(DbType,iConn,storeProcName,parameters));
((SqlDataAdapter)iDa).Fill(Ds);
if(iConn.State!=ConnectionState.Closed)
{
iConn.Close();
}
return Ds;
}
}
#endregion
}
}

一个很好用的SqlHelper类的更多相关文章

  1. 一个很棒的PHP缓存类,收藏下

    <?php class Cache { /** 缓存目录 **/ var $CacheDir = './cache'; /** 缓存的文件 **/ var $CacheFile = ''; /* ...

  2. 整理出一个比较实用的SqlHelper类 满足大多数情况的使用

    /// <summary> /// SqlHelper类 by zy 2016-3-11 /// </summary> public sealed class SqlHelpe ...

  3. c#中sqlhelper类的编写(二)

    上一篇文章讲了简易版的SqlHelper类的编写,我们在这里就上一篇文章末尾提出的问题写出解决方案. sql语句注入攻击已经是众所周知的了.我们如何在C#中保护自己的数据库不被这样的方式攻击呢? 不用 ...

  4. JAVA WEB SQLHelper类的封装

    在这次做项目中,我对自己最满意的就是封装了一下SQLHelper类,我对自己感到骄傲主要是 我是初学者,我刚开始不知道可以这样做,我只是想着试着去这样做了,结果真的可以,所以我 在我的模块就自己封装了 ...

  5. ADO.NET复习——自己编写SqlHelper类

    今天复习了一次ADO.NET基础,整理一下自己的认为的重点: 编写SqlHelper类,方便我们执行数据库语句,这时可以直接调用封装在SqlHelper类的方法.现在大多数公司面试的时候,给你的面试题 ...

  6. 用CIL写程序:定义一个叫“慕容小匹夫”的类

    前文回顾: <用CIL写程序:你好,沃尔德> <用CIL写程序:写个函数做加法> 前言: 今天是乙未羊年的第一天,小匹夫先在这里给各位看官拜个年了.不知道各位看官是否和匹夫一样 ...

  7. 最新的SqlHelper 类

    最新的SqlHelper 类 摘自:http://www.cnblogs.com/sufei/archive/2010/01/14/1648026.html using System; using S ...

  8. c#中sqlhelper类的编写(一)

    在.net平台的项目开发中,凡是用到数据库交互的,都有必要了解SqlHelper类的原理. 步骤一: 我就拿WPF项目开发作为例子.首先要新建一个App.config(应用程序配置文件).注意,在VS ...

  9. [置顶] 自己写sqlhelper类

    自己写sqlhelper类 using System; using System.Collections.Generic; using System.Configuration; using Syst ...

随机推荐

  1. 12_python_生成器

    一.生成器 python中有三种方式获取生成器 (1)通过生成器函数 (2)通过各种推导式来实现生成器 (3)通过数据的转换也可以获取生成器   1.只要函数中存在了yield,那么这个函数就是一个生 ...

  2. GoLang学习控制语句之字符串

    Go语言字符串是一种值类型,且值不可变,即创建某个文本后你无法再次修改这个文本的内容:更深入地讲,字符串是字节的定长数组.Go 代码使用 UTF-8 编码(且不能带 BOM),同时标识符支持 Unic ...

  3. 解决ssh远程连接错误问题

    使用 Xshell 远程连接服务器时,经常会出现这么个错误提示 WARNING! The remote SSH server rejected X11 forwarding request. ➜ ~ ...

  4. Python小白学习之路(二十五)—【装饰器的应用】

    通过一个任务来加深对装饰器的理解和应用 回顾:装饰器的框架 def timmer(func): def wrapper(): func() return wrapper 任务:给以下正在运行的程序加一 ...

  5. Note of The Linux Command Line

    心得 在用鼠标点击的图形化桌面之前,单纯用键盘操作软件的时代已经很成熟了.并且还在这样延续下去.鼠标不是电脑操作的唯一模式,至少不是程序员的. 在黑色屏幕下,因为没有鼠标所以只能用按键来操作软件.包括 ...

  6. python iter函数用法

    iter函数用法简述 Python 3中关于iter(object[, sentinel)]方法有两个参数. 使用iter(object)这种形式比较常见. iter(object, sentinel ...

  7. 利用Warensoft Stock Service编写高频交易软件--DEMO

    利用Warensoft Stock Service编写高频交易软件 无论是哪种交易软件,对于程序员来讲,最麻烦的就是去实现各种算法.本文以SAR算法的实现过程为例,为大家说明如何使用Warensoft ...

  8. Javac中的方法

    例1: interface IA{ void m(int a); } abstract class AC implements IA{ // 这个抽象方法覆盖了 IA中的方法m public abst ...

  9. Centos7下安装redis实战(单机版以及集群)

    一.背景 因项目需要,要引入redis做缓存,就在centos7下亲自安装了一遍redis,刚好趁着这个机会就来把redis的概念以及单机版和集群版redis安装步骤记录下来,在此和大家一起分享. 二 ...

  10. 自制“低奢内”CSS3登入表单,包含JS验证,请别嫌弃哦。

    要求 必备知识 基本了解CSS语法,初步了解CSS3语法知识.和JS/JQuery基本语法. 开发环境 Adobe Dreamweaver CS6 演示地址 演示地址 预览截图(抬抬你的鼠标就可以看到 ...