asp.net 多数据库支持的思考
更新时间:2009年07月29日 19:02:01 作者:
最近一直在思考如何做一个支持多种数据库的程序,打印了很多的资料,在.NET 2.0中,新增加了DbProviderFactory抽象工厂类,让数据层基类可以实现多种数据库,但在数据访问层中的参数部分我觉得是个麻烦。
一般的多数据库支持在配置文件中如下:
<connectionStrings>
<add name="MyCmsConnectionString" 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,有一些想法。
复制代码 代码如下:
<connectionStrings>
<add name="MyCmsConnectionString" 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,有一些想法。
相关文章
asp.net下用Aspose.Words for .NET动态生成word文档中的图片或水印的方法
本文详细讲解如何使用Aspose.Words for .NET的组件来生成word文档与水印的方法,请看本文内容。2010-04-04
ASP.NET Core 2.0中Razor页面禁用防伪令牌验证
在这篇短文中,我将向您介绍如何ASP.NET Core2.0 Razor页面中禁用防伪令牌验证,对此有兴趣的朋友参考学习下吧。2018-01-01


最新评论