在上篇关于SQLHelper类中,主要针对SQLServer数据库进行的。在使用别的数据库,就要修改部分代码!所以今天就写一个支持多数据库的封装!主要用到枚举,读取config文件!接口的简单用法。获取连接等...

一.config配置文件:

  <connectionStrings>
<add name="constr" connectionString="server=127.0.0.1;user id=用户名;password=密码;database=数据库名"/>
</connectionStrings>
<appSettings>
<add key="database" value ="MYSQL"/>
</appSettings>

关于连接字符串在SQLHelper帮助类_ 上 进行介绍  http://www.cnblogs.com/fengxuehuanlin/p/5271944.html

二.SqlHelper:

        private static string connstr;
/// <summary>
/// 从配置文件中获取连接字符串名,使用什么数据库
/// <appSettings>中key名:database,value值:数据库
/// <connectionStrings>name:constr
/// </summary>
static SqlHelper()
{
connstr = ConfigurationManager.ConnectionStrings["constr"].ConnectionString; //获取config文件中连接字符串
string databaseType = ConfigurationManager.AppSettings["database"].ToUpper();
DBdatabase.database = AdoHelper.EnumParse<DatabaseList>(databaseType); //将字符串转换成枚举类型
} /// <summary>
/// 获取相应数据库的连接
/// </summary>
/// <returns></returns>
public static IDbConnection getConnection()
{
string value = DBdatabase.database.ToString();
DatabaseList database= AdoHelper.EnumParse<DatabaseList>(value);
switch(database)
{
case DatabaseList.MYSQL:
return new MySqlConnection(connstr);
case DatabaseList.SQLSERVER:
return new SqlConnection(connstr);
default:
throw new Exception("数据库类型目前不支持!");
}
} /// <summary>
/// 将数据加载到本地,在本地对数据进行操作
/// </summary>
/// <param name="Sql">Sql语句</param>
/// <param name="parameter">参数化查询</param>
/// <returns>返回从数据库中读取到的DataTable表</returns>
public static DataTable ExecuteQuery(string Sql, params IDbDataParameter[] parameter)
{
using (IDbConnection conn=getConnection())
using (IDbCommand cmd = conn.CreateCommand())
{
conn.Open();
cmd.CommandText = Sql;
for (int i = ; i < parameter.Length; i++)
{
cmd.Parameters.Add(parameter[i]);
}
DataTable tab = new DataTable();
using (IDataReader reader = cmd.ExecuteReader())
{
tab.Load(reader);
return tab;
}
}
}
/// <summary>
/// 用于执行增加和删除语句
/// </summary>
/// <param name="Sql">Sql语句</param>
/// <param name="parameter">参数化查询</param>
/// <returns>有多少语句执行成功</returns>
public static int ExecuteNonQuery(string Sql, params IDbDataParameter[] parameter)
{
using (IDbConnection conn = getConnection())
using (IDbCommand cmd = conn.CreateCommand())
{
conn.Open();
cmd.CommandText = Sql;
for (int i = ; i < parameter.Length; i++)
{
cmd.Parameters.Add(parameter[i]);
}
return cmd.ExecuteNonQuery();
}
}
/// <summary>
/// 执行语句后,返回第一行第一列的数据
/// </summary>
/// <param name="Sql"></param>
/// <param name="parameter"></param>
/// <returns>object类型的值</returns>
public static object ExecuteScalar(string Sql, params IDbDataParameter[] parameter)
{
using (IDbConnection conn=getConnection())
using (IDbCommand cmd = conn.CreateCommand())
{
conn.Open();
cmd.CommandText = Sql;
for (int i = ; i < parameter.Length; i++)
{
cmd.Parameters.Add(parameter[i]);
}
return cmd.ExecuteScalar();
}
}
/// <summary>
/// 在数据库中,进行数据库的查询操作
/// </summary>
/// <param name="Sql"></param>
/// <param name="parameter"></param>
/// <returns></returns>
public static IDataReader ExecuteReader(string Sql, params IDbDataParameter[] parameter)
{
using (IDbConnection conn = getConnection())
using (IDbCommand cmd = conn.CreateCommand())
{
conn.Open();
cmd.CommandText = Sql;
for (int i = ; i < parameter.Length; i++)
{
cmd.Parameters.Add(parameter[i]);
}
return cmd.ExecuteReader(CommandBehavior.CloseConnection);
}
}
}
/// <summary>
/// 判断是什么数据库
/// </summary>
public class DBdatabase
{
public static DatabaseList database { get; set; }
}
public class AdoHelper
{
/// <summary>
/// 将字符串转换成枚举类型
/// </summary>
/// <typeparam name="T">枚举类型</typeparam>
/// <param name="value">字符串值</param>
/// <returns></returns>
public static T EnumParse<T>(string value)
{
return (T)Enum.Parse(typeof(T), value);
} /// <summary>
/// 对数据库进行操作
/// </summary>
/// <param name="conn">获取一个连接</param>
/// <returns></returns>
public static IDbCommand CreateCommand(IDbConnection conn)
{
IDbCommand cmd = conn.CreateCommand();
conn.Open();
return cmd;
}
}
/// <summary>
/// 数据库类型
/// </summary>
public enum DatabaseList
{
MYSQL = ,
SQLSERVER =
}

SQLHelper帮助类_下(支持多数据库的封装)的更多相关文章

  1. SqlHelper帮助类_上(SQLServer数据库含Connection详解)

    在操作数据库时,经常会用到自己封装的SqlHelper.这里主要对SQLServer数据库的Sqlhelper,主要用于在同一个连接中完成CRUD! 一.ADO.NET中的Connection详解: ...

  2. 非常不错的ASP操作数据库类,支持多数据库MSSQL,ACCESS,ORACLE,MYSQL等

    可同时操作多个不同类型的数据库. 完全不用考虑数据类型的差别,再也不用想字符型字段加不加单引号. 调用非常简单,对数据库的主要操作一般只需要一行代码. 支持mssql事务回滚. 可自动生成和输出sql ...

  3. EFCore高级Saas系统下一个DbContext如何支持多数据库迁移

    EFCore高级玩法单DbContext支持多数据库迁移 前言 随着系统的不断开发和迭代默认的efcore功能十分强大,但是随着Saas系统的引进efcore基于表字段的多租户模式已经非常完美了,但是 ...

  4. fastjson简单使用demo,@JSONField注解属性字段上与set、get方法上。实体类toString(),实体类转json的区别;_下划线-减号大小写智能匹配

    一.demo代码 @JSONField注解属性字段上与set.get方法上.使用@Data注解(lombok插件安装最下方),对属性“笔名”[pseudonym]手动重写setter/getter方法 ...

  5. 【原】thinkphp修改Redis操作类,支持选择数据库功能及添加其他方法

    版本3.2.2(ThinkPHP\Library\Think\Cache\Driver\Redis.class.php), 一:官方默认不支持选择数据库功能及,现就可选择数据库功能进行说明. 1 co ...

  6. 微软版的SqlHelper.cs类

    一,微软SQLHelper.cs类 中文版: using System; using System.Data; using System.Xml; using System.Data.SqlClien ...

  7. 微软SQLHelper.cs类 中文版

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Co ...

  8. C#_ 项目打包附加数据库

    C#_ 项目打包附加数据库 2010-07-11 23:22:45|  分类: Winfrom|举报|字号 订阅     实现效果:安装项目时直接附加数据库. 1.首先在需要部 署的项目的解决方案资源 ...

  9. 微软SQLHelper.cs类

    using System; using System.Data; using System.Xml; using System.Data.SqlClient; using System.Collect ...

随机推荐

  1. 4.ICMP协议,ping和Traceroute

    1.IMCP协议介绍 前面讲到了,IP协议并不是一个可靠的协议,它不保证数据被送达,那么,自然的,保证数据送达的工作应该由其他的模块来完成.其中一个重要的模块就是ICMP(网络控制报文)协议. 当传送 ...

  2. spark Intellij IDEA开发环境搭建

    (1)创建Scala项目 File->new->Project,如下图 选择Scala 然后next 其中Project SDK指定安装的JDK,Scala SDK指定安装的Scala(这 ...

  3. Spring 之 示例(Java之负基础实战)

    接 Spring 之 配置 里面的代码. 现在要进行Controller的开发. 1.引用类 import org.springframework.web.servlet.mvc.Controller ...

  4. --@ui-router--登录页通过路由跳转到内页的demo

    今天还是来说一下angular中的路由模块.我们实际项目中,各个页面的切换是经常会与Auth相关的.比如我网站的后台,是需要登录过的用户才能进去,那么我们用angularJS做前端路由的时候应该怎么完 ...

  5. SQL Server @@ERROR 用法

    @@error是系统函数,当没有发生错误时返回0,如果发生错误时@@error<>0,并返回错误号,每个SQL语句执行完,@@error值都会变. @@error只记录当前错误,如果存储过 ...

  6. Paxos 实现日志复制同步(Multi-Paxos)

    Paxos 实现日志复制同步 这篇文章以一种易于理解的方式来解释 Multi-Paxos 的机制. Multi-Paxos 的是为了创建日志复制 一种实现方式是用一组基础 Paxos 实例,每条记录都 ...

  7. yii2 中布局文件的 设置方法

    网页主题应用的属性: [yii\base\Application::layout|layout 该属性指定渲染 视图 默认使用的布局名字,默认值为 'main' 对应布局路径下的 main.php 文 ...

  8. Java日期工具类,Java时间工具类,Java时间格式化

    Java日期工具类,Java时间工具类,Java时间格式化 >>>>>>>>>>>>>>>>>&g ...

  9. 基于ssh反向代理实现的远程协助

    本文描述了怎么通过ssh反向代理实现远程协助,并提供了相关代码. 可满足web开启远程协助功能后,维护人员能够通过ssh和http登录客户机器(包括在nat环境下) web开启该功能后,ssh才能登录 ...

  10. 学习篇之String()

    // 3个特殊的引用类型:Boolean,Number,String var s1 = "some text"; ,); // me t ,); // me ,-); // so ...