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);
        }
    }
}
以上代码即可实现:根据配置文件设置的数据库类型,动态实例化对应的数据库访问对象。



完整代码下载

目录
相关文章
|
19天前
|
网络协议 关系型数据库 Linux
Linux系统中如何开启和配置OpenGauss数据库的远程连接
openGauss是一款开源关系型数据库管理系统,采用木兰宽松许可证v2发行。openGauss内核深度融合华为在数据库领域多年的经验,结合企业级场景需求,持续构建竞争力特性.
|
15天前
|
关系型数据库 MySQL 数据库
MySQL技能完整学习列表——1、数据库基础概念——2、数据库管理系统(DBMS)——3、数据模型(Data Model)
MySQL技能完整学习列表——1、数据库基础概念——2、数据库管理系统(DBMS)——3、数据模型(Data Model)
14 0
|
16天前
|
前端开发 数据库连接 数据库
ASP.NETMVC数据库完整CRUD操作示例
ASP.NETMVC数据库完整CRUD操作示例
19 0
|
16天前
|
SQL 开发框架 .NET
ASP.NET WEB+EntityFramework数据持久化——考核练习库——1、用户管理系统(考点:查询列表、增加、删除)
ASP.NET WEB+EntityFramework数据持久化——考核练习库——1、用户管理系统(考点:查询列表、增加、删除)
52 0
|
21天前
|
存储 BI 数据库
SAP ABAP 系统数据库表 TFDIR的作用介绍
SAP ABAP 系统数据库表 TFDIR的作用介绍
20 1
|
23天前
|
前端开发 Java 数据库
现代数据库管理系统及其应用
现代数据库管理系统(DBMS)是计算机科学领域的重要组成部分,它在各个行业和领域中发挥着重要作用。本文将介绍数据库管理系统的基本概念、特点和分类,并探讨其在前端开发、后端开发以及Java、Python和C等编程语言中的应用。
|
24天前
|
Cloud Native 关系型数据库 分布式数据库
凭安征信引入阿里云PolarDB云数据库支撑企业征信核心业务系统
凭安征信是国家中小企业公共服务示范平台,主营信用管理服务包括信用管家、水滴信用及可信认证。通过采用阿里云PolarDB云原生数据库替代RDS数据库帮助客户全面实现业务系统性能提升1-2倍,通过PolarDB企业级能力的加持下,运维更加简便,操作更加简单,数据安全能力更强。
|
25天前
|
存储 数据库 开发者
现代数据库管理系统中的索引设计与优化
索引是数据库管理系统中的重要组成部分,对于提高查询性能和数据访问效率至关重要。本文将探讨现代数据库管理系统中的索引设计与优化策略,包括索引类型、索引选择原则、索引优化技巧等。通过深入理解索引的内部工作原理和优化策略,开发者可以更好地利用索引提升数据库性能。
|
25天前
|
存储 供应链 安全
新一代数据库技术——基于区块链的分布式存储系统
传统数据库系统通常采用集中式存储结构,容易受到单点故障和数据篡改的影响。本文将介绍基于区块链技术的分布式存储系统,探讨其在数据库领域的应用和优势,以及面临的挑战和未来发展趋势。
26 1
|
27天前
|
数据可视化 Serverless 数据库
Serverless应用引擎部署问题之数据库访问失败如何解决
Serverless部署是指将应用程序部署到无服务器架构中,该架构允许开发者专注于代码而无需关心底层服务器的运行和维护;针对Serverless部署过程中可能遇到的挑战,本合集提供全面的指南和最佳实践,帮助开发者顺利实现应用的无服务器化部署。