最近一直在思考如何做一个支持多种数据库的程序,打印了很多的资料,在.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,有一些想法。