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



完整代码下载

目录
相关文章
|
7天前
|
缓存 监控 Java
优化Spring Boot应用的数据库访问性能
优化Spring Boot应用的数据库访问性能
|
8天前
|
存储 SQL 关系型数据库
现代数据库管理系统的发展与挑战
数据库管理系统(DBMS)作为现代软件开发的核心组成部分,其在数据存储、管理和访问方面的演进至关重要。本文探讨了现代DBMS的发展历程、关键技术特点以及面临的挑战,包括大数据处理、云计算环境下的优化和安全性等方面。 【7月更文挑战第7天】
|
6天前
|
存储 自然语言处理 DataWorks
通过云上数据库三步构建RAG系统
本文介绍了如何使用OpenSearch LLM智能问答版通过云上数据库一站式构建RAG系统。
144 1
|
7天前
|
缓存 监控 Java
优化Spring Boot应用的数据库访问性能
优化Spring Boot应用的数据库访问性能
|
9天前
|
开发框架 监控 NoSQL
.NET开源的实时应用监控系统 - WatchDog
.NET开源的实时应用监控系统 - WatchDog
|
9天前
|
SQL JavaScript 安全
基于.NET开源跨平台的文档管理系统
基于.NET开源跨平台的文档管理系统
|
9天前
|
数据库
超算系统构思01----数据库必须有一个公式系统,右侧选择你想要的公式,要明白的地方,公式在计算机上的表达,数据库必须记住的东西是公式,先做公式,必须得做
超算系统构思01----数据库必须有一个公式系统,右侧选择你想要的公式,要明白的地方,公式在计算机上的表达,数据库必须记住的东西是公式,先做公式,必须得做
|
10天前
|
存储 安全 算法
数据库系统工程师笔记(一)计算机系统
数据库系统工程师笔记(一)计算机系统
11 0
|
9天前
|
存储 关系型数据库 MySQL
探索MySQL:关系型数据库的基石
MySQL,作为全球最流行的开源关系型数据库管理系统(RDBMS)之一,广泛应用于各种Web应用、企业级应用和数据仓库中
|
6天前
|
关系型数据库 MySQL 网络安全
Mysql 数据库主从复制
在MySQL主从复制环境中,配置了两台虚拟机:主VM拥有IP1,从VM有IP2。主VM的`my.cnf`设置server-id为1,启用二进制日志;从VM设置server-id为2,开启GTID模式。通过`find`命令查找配置文件,编辑`my.cnf`,在主服务器上创建复制用户,记录二进制日志信息,然后锁定表并备份数据。备份文件通过SCP传输到从服务器,恢复数据并配置复制源,启动复制。检查复制状态确认运行正常。最后解锁表,完成主从同步,新用户在从库中自动更新。
909 6
Mysql 数据库主从复制