多层多数据库模式开发的实验(四)数据层-工厂

    在框架设计中,我已经说了本实验针对Access和SQLServer两种数据库进行访问。为了做到多数据库能动态访问,我们仅仅需要进行简单设置即可的目标。这就需要用到工厂和反射配合。我们先看工厂的实现:

ContractedBlock.gif ExpandedBlockStart.gif Code
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using System.Reflection;
using System.Configuration;
using MWC.Interface;

namespace MWC.DAL.Factory
ExpandedBlockStart.gifContractedBlock.gif
{
    
public class AccessFactory
ExpandedSubBlockStart.gifContractedSubBlock.gif    
{
        
private static readonly string AssemblyName = "MWC.DAL." + ConfigurationSettings.AppSettings["DBType"];

        
public static IUser UserFactory()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            
string ClassName = AssemblyName + ".User";

            
return (IUser)Assembly.Load(AssemblyName).CreateInstance(ClassName);
        }


        
public static IGroup GroupFactory()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
{
            
string ClassName = AssemblyName + ".Group";

            
return (IGroup)Assembly.Load(AssemblyName).CreateInstance(ClassName);
        }

    }

}

 

    使用反射,每个层只需要一个工厂,然后通过从配置文件中读出程序集的名称,动态加载相应类。我们来看web.config文件中的设置:

ContractedBlock.gif ExpandedBlockStart.gif Code
<appSettings>
    
<!--
    
<add key="DBType" value="Access"/>
    
<add key="DBType" value="SQLServer"/>
    
-->
    
<add key="DBType" value="Access"/>
    
<add key="AccessConnectionString" value="Provider=Microsoft.Jet.OLEDB.4.0;Data Source={DBPath}"/>
    
<add key="AccessPath" value="~/App_Data/mwcard.mdb"/>
    
<add key="SQLServerConnectionString" value="Data Source=TEST2008\SQLEXPRESS;Initial Catalog=mwcard;Integrated Security=True;Pooling=False"/>
</appSettings>

 

    在实际使用中,我们只要设置“DBType”键值的内容是“Access”或“SQLServer”即可。AccessFactory利用反射来调用“MWC.DAL.Access”或“MWC.DAL.SQLServer”类。

    这样,逻辑层就不关心后台是什么数据库,只要调用对应的类对象而已。

    注:记得在本模块工程中引用添加“MWC.Interface”,并在文件中添加“using MWC.Interface”。另外,我们应用了反射,所以需要在文件中添加“using System.Reflection”。

转载于:https://www.cnblogs.com/squabbyfish/archive/2008/11/06/1327438.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值