开发框架数据库配置的几种应用场景

在个人开发框架系列中,底层数据库的配置处理都是差很少的,框架总体支持SQLServer、DB二、MySql、ODP.NET(Oracle)、PostgreSQL、SQLite、SqlEx等数据库的,每每客户在使用框架的时候会问,框架支持哪些数据库、各类数据库配置信息、如何实现数据库分库处理、如何同时支持SQLServer和Oracle等数据库支持、如何实现数据库链接字符串加密等问题,本篇随笔逐一进行介绍。html

一、框架支持的数据库介绍

框架底层数据库访问采用了微软企业库实现,所以在处理多种数据库访问的时候,可以提供统一的访问处理操做,同时对不一样的数据库支持操做也是很是不错的。下图是框架底层数据库的支持状况。mysql

采用了微软企业库Enterprise Library做为咱们底层的数据库访问模块后,对于多种数据库的访问操做,就会统一采用这个企业库的数据库访问对象,操做起来很是一致,为了对不一样数据库的常规增删改查等一些操做进行进一步的封装,以达到简化代码的目的,所以咱们能够为每一个不一样的数据库定义一个数据访问操做基类,以便实现一些不一样数据库差别性的处理,可是它们仍是有一个共同的数据访问基类。sql

采用不一样的数据库,咱们须要为不一样数据库的访问层进行生成处理,如为SQLServer数据的表生成相关的数据访问层DALSQL,里面放置各个表对象的内容,不过因为采用了相关的继承类处理和基于数据库的代码生成,须要调整的代码不多。数据库

这样整合多种数据库支持的底层后,整个数据访问的架构设计以下所示。架构

 

二、各类数据库配置信息

对于默认支持的SQLServer数据库,它的链接字符串以下所示。oracle

<?xml version="1.0"?>
<configuration>
  <configSections>
    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data"/>
  </configSections>
  <connectionStrings>
    <!--SQLServer数据库的链接字符串-->
    <add name="sqlserver" providerName="System.Data.SqlClient" connectionString="Persist Security Info=False;Data Source=(local);Initial Catalog=WinFramework;Integrated Security=SSPI"/>
  </connectionStrings>
  <dataConfiguration defaultDatabase="sqlserver">
  </dataConfiguration>
</configuration>

上面的sqlserver数据库链接信息是采用信任模式配置的,若是咱们基于局域网,那么须要配置对应的IP或者sa用户名和密码的方式,配置信息以下所示。app

<add name="sqlserver2" providerName="System.Data.SqlClient" connectionString="Data Source=192.168.1.10;Initial Catalog=CRM;Persist Security Info=True;User ID=sa;Password=123456"/>

不过对于一些扩展支持的数据库,咱们还须要添加一些映射处理,如对于MySQL的支持,咱们须要添加链接字符串:框架

  <!--MySQL数据库的链接字符串-->
    <add name="mysql" providerName="MySql.Data.MySqlClient" connectionString="Server=localhost;Database=WinFramework;Uid=root;Pwd=123456;"/>

还须要添加ProviderMappings的支持,以下所示的XML。ide

  <dataConfiguration defaultDatabase="mysql">
    <providerMappings>
      <add databaseType="EntLibContrib.Data.MySql.MySqlDatabase, EntLibContrib.Data.MySql" name="MySql.Data.MySqlClient" />
    </providerMappings>
  </dataConfiguration>

下面我列出全部不一样数据库的链接字符串以及映射关系的一个完整版本,供参考。函数

<?xml version="1.0"?>
<configuration>
  <configSections>
    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data"/>
  </configSections>
  <connectionStrings>
    <!--Sqlserver数据库的链接字符串-->
    <add name="sqlserver" providerName="System.Data.SqlClient" connectionString="Persist Security Info=False;Data Source=(local);Initial Catalog=WinFramework;Integrated Security=SSPI"/>

    <!--PostgreSQL数据库的链接字符串-->
    <add name="npgsql" providerName="Npgsql" connectionString="Server=localhost;Port=5432;Database=postgres;User Id=postgres;Password=123456"/>
    <!--MySQL数据库的链接字符串-->
    <add name="mysql" providerName="MySql.Data.MySqlClient" connectionString="Server=localhost;Database=WinFramework;Uid=root;Pwd=root;"/>
    <!--路径符号|DataDirectory|表明当前运行目录-->
    <add name="access" providerName="System.Data.OleDb" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\WinFramework.mdb;User ID=Admin;Jet OLEDB:Database Password=;" />
    <!--sqlite数据库字符串,路径符号|DataDirectory|表明当前运行目录-->
    <add name="sqlite"  providerName="System.Data.SQLite" connectionString="Data Source=|DataDirectory|\WinFramework.db;Version=3;" />
    <!--Oracle数据库的链接字符串-->
    <add name="oracle" providerName="System.Data.OracleClient" connectionString="Data Source=orcl;User ID=win;Password=win"/>
    <!--达梦数据库的链接字符串-->
    <add name="Dm" providerName="Dm" connectionString="Server=localhost;User ID=SYSDBA;PWD=SYSDBA;Database=WINFRAMEWORK;" />
    <!--IBM DB2数据库的链接字符串-->
    <add name="db2" providerName="IBM.Data.DB2"    connectionString="database=whc;uid=whc;pwd=123456"/>
    <!--采用OdpNet方式的Oracle数据库的链接字符串-->
    <add name="oracle2"    providerName="Oracle.DataAccess.Client"    connectionString="Data Source=orcl;User id=win;Password=win;" />
  </connectionStrings>
  <dataConfiguration defaultDatabase="sqlserver">
    <providerMappings>
      <add databaseType="EntLibContrib.Data.PostgreSql.NpgsqlDatabase, EntLibContrib.Data.PostgreSql" name="Npgsql" />
      <add databaseType="EntLibContrib.Data.MySql.MySqlDatabase, EntLibContrib.Data.MySql" name="MySql.Data.MySqlClient" />
      <add databaseType="EntLibContrib.Data.SQLite.SQLiteDatabase, EntLibContrib.Data.SqLite" name="System.Data.SQLite" />
      <add databaseType="EntLibContrib.Data.Dm.DmDatabase, EntLibContrib.Data.Dm" name="Dm" />
      <add databaseType="EntLibContrib.Data.DB2.DB2Database, EntLibContrib.Data.DB2" name="IBM.Data.DB2" />
      <add databaseType="EntLibContrib.Data.OdpNet.OracleDatabase, EntLibContrib.Data.OdpNet" name="Oracle.DataAccess.Client" />
    </providerMappings>
  </dataConfiguration>
  <appSettings>
    <!--组件的数据库类型:access、sqlserver、sqlite、oracle等,默认为sqlserver可不写-->
    <add key="ComponentDbType" value="sqlserver"/>
  </appSettings>
  <startup useLegacyV2RuntimeActivationPolicy="true">
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/>
    <supportedRuntime version="v2.0.50727"/>
  </startup>
</configuration>

里面包括了支持的各类数据库的链接字符串的写法。

 

三、如何实现数据库分库处理、如何同时支持SQLServer和Oracle等数据库支持 

因为整个框架的设计抽象了多种数据库的处理模型,所以数据库分库处理实现也是比较方便的,数据库的分库处理和同时支持SQLServer和Oracle等数据库的操做是相似的,他们都是对多个数据库(包括不一样各种型)进行访问处理。

以前我在随笔《Winform开发框架中实现多种数据库类型切换以及分拆数据库的支持》这里也介绍了具体的实现处理,其实咱们使用的同时支持多数据库的操做代码是比较简单的,咱们能够在代码里面经过调用BLL层类的接口SetConfitName来指定特定的数据库,以下代码所示。

            //指定业务类的数据库配置
            BLLFactory<Asset>.Instance.SetConfigName("workflow");  
            BLLFactory<StoreAddress>.Instance.SetConfigName("workflow"); 

有时候,可能BLL对象有可能出现相同的状况,可是须要访问不一样库里面的表对象,那么咱们能够在使用后恢复默认的配置信息。

            BLLFactory<DictData>.Instance.SetConfigName("workflow");//使用业务库
            Dictionary<string, string> dict = BLLFactory<DictData>.Instance.GetDictByDictType(dictTypeName);
            BLLFactory<DictData>.Instance.SetConfigName(null);//恢复默认

以上代码就是先访问workflow配置的数据库信息,获取字典信息后恢复默认的数据库信息。

上面那种方式是对于同种类型数据库的接口切换,若是不一样的数据库类型,如一个是SQLServer,一个是Oracle,那么就能够多指定一个参数便可,以下代码所示。

            //指定使用oracle类型的数据库配置
            BLLFactory<DictData>.Instance.SetConfigName("workflow", "oracle");//使用业务库
            Dictionary<string, string> dict = BLLFactory<DictData>.Instance.GetDictByDictType(dictTypeName);
            BLLFactory<DictData>.Instance.SetConfigName(null);//恢复默认

虽然咱们通常使用一个库,可是若是是分库,或者要同时支持多个数据库类型,基本上处理仍是很方便的。

若是对于通用类型的数据库处理,咱们可使用公用类库里面的CommonDAL类进行处理。这个类库能够很方便的处理视图、存储过程、或者常规的接口查询操做,不须要和具体的实体类绑定的接口。

它的定义以下所示。

 

四、数据库字符串加密处理

不少状况下,咱们为了部署应用,须要公开数据库链接字符串信息,可是咱们又不想让使用者很容易的获取到咱们的链接字符串里面的用户名和密码敏感信息,这时候链接字符串加密就是比较必要的了。

处理方式就是咱们建立一个工具,使用本身知道的加解密规则来处理链接字符串的加解密处理。

处理的过程大概以下所示。

1)找到app.config文件,打开内容编辑。
2)找到数据库(如SQLServer)链接字符串的connectionString字符串,以下所示。
<add name="sqlserver" providerName="System.Data.SqlClient" connectionString="Persist Security Info=False;Data Source=(local);Initial Catalog=CRM;Integrated Security=SSPI"/>
3)提取里面的connectionString字符串部分,放到上面的加密软件里面进行加密,而后把加密内容替换connectionString字符串,变为以下所示的配置信息。
<add name="sqlserver" providerName="System.Data.SqlClient" connectionString="9Fs/vPhm24CYa0mXCLAMYOJmbBHq/qQAjdbVdbeOhS5L0d8WGhHUR3iIyFZydEV8cPmlPHfDTnwJZMr9xkMAxuNtPKUsIdKTjlWInpf+Vc+UD2gtYIE3FnvL06KcHzX+"/>

4)保存文件,配置加密字符串完成。

这个配置信息在框架的处理的时候有对应的解密处理规则,能够正常解析加密字符串便可。

若是要了解或者修改其中的对应解密处理操做,能够定位扩展公用类库里面数据库访问层,以下所示。

定位到对应的数据库访问类,而后找到下面的对应函数了解便可。

相关文章
相关标签/搜索