ASP.NET 系统支持数据库访问设计

系统设计时,往往要考虑到兼容多种数据库,拿常见的三种数据库:SqlServer,MySql,Oracle为例,常见的三层设计可以分为:业务逻辑层,数据访问层,实体层;他们的结构大致如下:

三种数据库对应有三套数据库访问类,为了方便组织代码,往往将读写一种数据库的类放到对应命名的文件夹下,代码结构大概如下:

业务逻辑层:

以上面的代码为例,业务逻辑层要调用数据访问层时,可以这样来实例化数据库访问对象:var db = DbFactory.GetService<IAdministrator>();

数据访问层:

关键点在于如何动态实例化数据库访问对象,即上面的DbFactory.GetService方法如何实现。

using System;
using System.Configuration;
using System.Reflection;

namespace Whir.Website.Admin.Repository
{
    public class DbFactory
    {
        public static T GetService<T>()
        {
            string dbType = ConfigurationManager.AppSettings.Get("DbType");
            Type interfaceType = typeof(T);
            Assembly[] assemblies = AppDomain.CurrentDomain.GetAssemblies();
            foreach (Assembly assembly in assemblies)
            {
                string asmName = assembly.FullName.Contains(",")
                                     ? assembly.FullName.Substring(0,
                                                                   assembly.FullName.IndexOf(",",
                                                                                             StringComparison
                                                                                                 .Ordinal))
                                     : assembly.FullName;
                if (assembly.FullName.ToLower().StartsWith("whir"))
                {
                    //查找 接口所在程序集的类
                    if (interfaceType.Namespace != null
                        &&
                        (interfaceType.Namespace.Length >= asmName.Length && interfaceType.Namespace.Contains(asmName)))
                    {
                        Type[] classes = assembly.GetTypes();
                        foreach (Type type in classes)
                        {
                            //查找条件:
                            //1.实现了接口的类;
                            //2.类所在的命名空间含有配置文件配置的数据类型;
                            if (IsInherit(type, interfaceType)
                                && (type.Namespace != null && type.Namespace.ToLower().Contains(dbType.ToLower())))
                            {
                                var temp = (T)Activator.CreateInstance(type);
                                return temp;
                            }
                        }
                    }
                }
            }
            return default(T);
        }

        public static bool IsInherit(Type type, Type baseType)
        {
            if (type.BaseType == null) return false;
            if (type.BaseType == baseType || baseType.IsAssignableFrom(type))
                return true;
            return IsInherit(type.BaseType, baseType);
        }
    }
}

以上代码即可实现:根据配置文件设置的数据库类型,动态实例化对应的数据库访问对象。

完整代码下载

时间: 2024-08-27 03:39:30

ASP.NET 系统支持数据库访问设计的相关文章

在 ASP.NET 中支持数据库缓存相关性

asp.net|缓存|数据|数据库 开发人员都喜欢 ASP.NET 应用程序缓存. 一个原因是 ASP.NET 能够在放入缓存中的项与文件系统中的文件之间创建相关性. 如果相关性所针对的文件更改,ASP.NET 会自动将相关项从缓存中删除. 通过与缓存删除回叫(当缓存项删除时向所有关注方广播通知)结合,缓存相关性为开发人员提供了方便,使他们得以通过尽量减少耗时的文件访问来最大限度地提高性能,因为这使他们可以放心地允许文件数据缓存,而不必担心数据变得陈旧. 尽管缓存相关性非常实用,但是在 ASP.

mysql-火车售票系统的数据库如何设计

问题描述 火车售票系统的数据库如何设计 模拟火车售票系统,有登陆注册查询购票功能,用户不存在权限,仅仅是乘客进行购票. 模拟火车票数据库需要的数据进行设计,以票面信息为中心,考虑旅客.火车等的信息. 站点就模拟:济南-泰安-徐州-南京-上海就好,起点统一为"济南",然后终点可能是"泰安.徐州.南京.上海". 我该如何统筹站点信息 列车信息 座位信息 车票信息 车厢信息?这里面我是需要一个车次信息表 (列车编号,车次,始发站,终点站,发时,到时,车厢数,卧铺车厢数,里

《解剖PetShop》系列之二:PetShop数据访问层之数据库访问设计

在系列一中,我从整体上分析了PetShop的架构设计,并提及了分层的概念.从本部分开始,我将依次对各层进行代码级的分析,以求获得更加细致而深入的理解.在PetShop 4.0中,由于引入了ASP.Net 2.0的一些新特色,所以数据层的内容也更加的广泛和复杂,包括:数据库访问.Messaging.MemberShip.Profile四部分.在系列二中,我将介绍有关数据库访问的设计. 在PetShop中,系统需要处理的数据库对象分为两类:一是数据实体,对应数据库中相应的数据表.它们没有行为,仅用于

ASP.NET/Perl.NET 数据库访问例子

asp.net|perl|访问|数据|数据库 ASP.NET/Perl.NET Database Access ExampleOne of the features of the .NET framework is its ability to handle multiple languages. Third party compiler vendors can create and implement a compiler targeted for the .NET runtime. In f

网吧计时收费系统的数据库如何设计阿?

问题描述 我是要用C#2005winForm+sql2005开发一个网吧计时收费系统,但是现在我不知道如何设计数据库哪位大哥帮个忙阿(数据库至少五张表) 解决方案 解决方案二:网上有好多例子呢,下载下来看看就好了.不知道你的需求具体是什么要不设计这样简单的数据库是很容易的

《解剖PetShop》之二:PetShop数据访问层数之据库访问设计_自学过程

二.PetShop数据访问层之数据库访问设计 在系列一中,我从整体上分析了PetShop的架构设计,并提及了分层的概念.从本部分开始,我将依次对各层进行代码级的分析,以求获得更加细致而深入的理解.在PetShop 4.0中,由于引入了ASP.Net 2.0的一些新特色,所以数据层的内容也更加的广泛和复杂,包括:数据库访问.Messaging.MemberShip.Profile四部分.在系列二中,我将介绍有关数据库访问的设计. 在PetShop中,系统需要处理的数据库对象分为两类:一是数据实体,

建立JSP操作提高数据库访问效率

js|访问|数据|数据库     从服务器端促进程序快速开发的Java Server Pages (JSP)决定它成为一种广为流行的工具.虽然呆板的一面仍然存在,然而无论它包含多少缺点,JSP能够为Web程序设计者提供很多东西,尤其是与数据库的输入和输出操作与数据的处理.     通过JSP来进行数据库访问不需要太多的引导.问题是如何使开发者能够接受Web程序的数据库访问比传统的本地OLAP系统的数据库访问更加具有吸引力,并且使他们认识到,整洁和简要的数据访问方法才是关键的.在这一点上,JSP可

建立JSP操作以提高数据库访问的效率

js|访问|数据|数据库     从服务器端促进程序快速开发的Java Server Pages (JSP)决定它成为一种广为流行的工具.虽然呆板的一面仍然存在,然而无论它包含多少缺点,JSP能够为Web程序设计者提供很多东西,尤其是与数据库的输入和输出操作与数据的处理. 通过JSP来进行数据库访问不需要太多的引导.问题是如何使开发者能够接受Web程序的数据库访问比传统的本地OLAP系统的数据库访问更加具有吸引力,并且使他们认识到,整洁和简要的数据访问方法才是关键的.在这一点上,JSP可以很好地

如何建立JSP操作用以提高数据库访问效率

从服务器端促进程序快速开发的Java Server Pages (JSP)决定它成为一种广为流行的工具.虽然呆板的一面仍然存在,然而无论它包含多少缺点,JSP能够为Web程序设计者提供很多东西,尤其是与数据库的输入和输出操作与数据的处理. 通过JSP来进行数据库访问不需要太多的引导.问题是如何使开发者能够接受Web程序的数据库访问比传统的本地OLAP系统的数据库访问更加具有吸引力,并且使他们认识到,整洁和简要的数据访问方法才是关键的.在这一点上,JSP可以很好地解决. 你能够做哪些? 如果你正在