最近一直在思考如何做一个支持多种数据库的程序,打印了很多的资料,在.NET 2.0中,新增加了DbProviderFactory抽象工厂类,让数据层基类可以实现多种数据库,但在数据访问层中的参数部分我觉得是个麻烦。
一般的多数据库支持在配置文件中如下: 
复制代码 代码如下:
 
<connectionStrings> 
<add connectionString="server=(local);user id=sa;pwd=123456;database=mycms;"/> 
</connectionStrings> 
而数据库连接如下:
复制代码 代码如下:
 
using System; 
using System.Collections.Generic; 
using System.Text; 
using System.Configuration; 
using System.Data; 
using System.Data.Common; 
namespace COMMON 
{ 
public class Class1 
{ 
public DbConnection GetDatabaseConnection() 
{ 
ConnectionStringSettings settings = ConfigurationManager.ConnectionStrings["Conn"]; 
DbProviderFactory factory = DbProviderFactories.GetFactory(settings.ProviderName); 
DbConnection conn = factory.CreateConnection(); 
conn.ConnectionString = settings.ConnectionString; 
return conn; 
} 
} 
} 
但接下来呢?研究了discuz和其他一些支持多数据库的cms,有一些想法。
