文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么为ABP框架配置数据库

2023-06-29 07:10

关注

本篇内容主要讲解“怎么为ABP框架配置数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么为ABP框架配置数据库”吧!

在 AbpBase.Database 中,通过 Nuget 添加以下几个库:

版本都是 1.9.0-preview0917,你可以使用最新版本的。

FreesqlFreeSql.Provider.SqliteFreeSql.Provider.SqlServerFreeSql.Provider.MySql

创建标准的 EFCore 数据库上下文

在 ABP 中,EFCore 上下文类需要继承 AbpDbContext<T>,整体编写方法跟继承 DbContext<T> 一致 ,接下来我们将一步步来讲解在 AbpBase 中如何添加 EFCore 功能。

连接字符串

ABP 中,可以在上下文类加上一个 ConnectionStringName 特性,然后在配置服务时,ABP 会自动为其配置连接字符串。

    [ConnectionStringName("Default")]    public partial class DatabaseContext : AbpDbContext<DatabaseContext>

Default 是一个标识,你也可以填写其他字符串标识。

定义隔离的上下文

首先,我们在 AbpBase.Database 模块中,创建两个文件夹:

BaseDataExtensionData

BaseData 目录用来存放基础表结构的上下文,ExtensionData 用来存放可能会拓展或者经常变动的表结构。

在 BaseData 中创建一个 AbpBaseDataContext 类,其内容如下:

using Microsoft.EntityFrameworkCore;using Volo.Abp.Data;using Volo.Abp.EntityFrameworkCore;namespace AbpBase.Database{    /// <summary>    /// 上下文    /// <para>这部分用于定义和配置基础表的映射</para>    /// </summary>    [ConnectionStringName("Default")]    public partial class AbpBaseDataContext : AbpDbContext<AbpBaseDataContext>    {        #region 定义 DbSet<T>        #endregion        public AbpBaseDataContext(DbContextOptions<AbpBaseDataContext> options)    : base(options)        {        }        /// <summary>        /// 定义映射        /// </summary>        /// <param name="modelBuilder"></param>        protected override void OnModelCreating(ModelBuilder modelBuilder)        {            #region 定义 映射            #endregion            OnModelCreatingPartial(modelBuilder);        }        partial void OnModelCreatingPartial(ModelBuilder modelBuilder);    }}

在 ExtensionData 中也创建一个相同的 AbpBaseDataContext 类,其内容如下:

using Microsoft.EntityFrameworkCore;namespace AbpBase.Database{    public partial class AbpBaseDataContext    {        #region 定义 DbSet<T>        #endregion        /// <summary>        /// 定义映射        /// </summary>        /// <param name="modelBuilder"></param>        partial void OnModelCreatingPartial(ModelBuilder modelBuilder)        {        }    }}

分部类,前者用于定义那些非常基础的,程序核心的实体(表)以及映射。而后者定义后续可能多次修改的,设计时感觉有设计余地的。

多数据库支持和配置

这里我们将对上下文进行配置和注入,使得程序能够支持多数据库。

在 AbpBase.Domain.Shared 项目中,创建一个枚举,其内容如下:

namespace AbpBase.Domain.Shared{    public enum AbpBaseDataType    {        Sqlite = 0,        Mysql = 1,        Sqlserver = 2        // 其他数据库    }}

再创建一个 WholeShared 类,其内容如下:

namespace AbpBase.Domain.Shared{    /// <summary>    /// 全局共享内容    /// </summary>    public static class WholeShared    {        // 数据库连接属性可以自行在配置文件中定义,这里写固定的,只是为了演示        /// <summary>        /// 数据库连接字符串        /// </summary>        public static readonly string SqlConnectString = "";        /// <summary>        /// 要使用的数据库类型        /// </summary>        public static readonly AbpBaseDataType DataType = AbpBaseDataType.Sqlite;    }}

然后我们在 AbpBaseDatabaseModule 模块中的 ConfigureServices 函数里面添加依赖注入:

context.Services.AddAbpDbContext<AbpBaseDataContext>();

这里不需要配置数据库连接字符串,后面可以通过 ABP 的一些方法来配置。

配置上下文连接字符串

            string connectString = default;            Configure<AbpDbConnectionOptions>(options =>            {                connectString = WholeShared.SqlConnectString;                options.ConnectionStrings.Default = connectString;            });

配置多数据库支持:

            FreeSql.DataType dataType = default;            Configure<AbpDbContextOptions>(options =>            {                switch (WholeShared.DataType)                {                    case AbpBaseDataType.Sqlite:                        options.UseSqlite<AbpBaseDataContext>(); dataType = FreeSql.DataType.Sqlite; break;                    case AbpBaseDataType.Mysql:                        options.UseMySQL<AbpBaseDataContext>(); dataType = FreeSql.DataType.MySql; break;                    case AbpBaseDataType.Sqlserver:                        options.UseSqlServer<AbpBaseDataContext>(); dataType = FreeSql.DataType.SqlServer; break;                }            });

这样就完成了对 EFCore 的多数据库配置了。

下面我们来使用类似的方法配置 Freesql。

Freesql 配置服务

首先,Freesql 里面有多种配置方式,例如 DbContext,读者可以到 Wiki 去学习 Freesql

https://github.com/dotnetcore/FreeSql/wiki/%E5%85%A5%E9%97%A8

笔者这里使用的是 “非正规” 的设计方式,哈哈哈哈。

在 BaseData 目录中,创建一个 FreesqlContext 类,其内容如下:

using FreeSql.Internal;using System;using System.Collections.Generic;using System.Text;namespace AbpBase.Database{    /// <summary>    /// Freesql 上下文    /// </summary>    public partial class FreesqlContext    {        public static IFreeSql FreeselInstance => Freesql_Instance;        private static IFreeSql Freesql_Instance;        public static void Init(string connectStr, FreeSql.DataType dataType = FreeSql.DataType.Sqlite)        {            Freesql_Instance = new FreeSql.FreeSqlBuilder()                .UseNameConvert(NameConvertType.PascalCaseToUnderscore)                .UseConnectionString(dataType, connectStr)                //.UseAutoSyncStructure(true) // 自动同步实体结构到数据库,生产环境禁止使用!                .Build();            OnModelCreating(Freesql_Instance);        }        private static void OnModelCreating(IFreeSql freeSql)        {            OnModelCreatingPartial(freeSql);        }    }}

ExtensionData 目录中,创建 FreesqlContext 类 如下:

using FreeSql;using System;using System.Collections.Generic;using System.Text;namespace AbpBase.Database{    public partial class FreesqlContext    {        private static void OnModelCreatingPartial(IFreeSql freeSql)        {            var modelBuilder = freeSql.CodeFirst;            SyncStruct(modelBuilder);        }        /// <summary>        /// 同步结构到数据中        /// </summary>        /// <param name="codeFirst"></param>        private static void SyncStruct(ICodeFirst codeFirst)        {            //  codeFirst.SyncStructure(typeof(user));        }    }}

然后在 AbpBaseDatabaseModule 的 ConfigureServices 函数中添加注入服务:

            FreesqlContext.Init(connectString, dataType);            context.Services.AddSingleton(typeof(IFreeSql), FreesqlContext.FreeselInstance);            context.Services.AddTransient(typeof(FreesqlContext), typeof(FreesqlContext));

通过以上步骤,我们的 ABP 就可以支持多数据库了,EFCore + Freesql,并且将将表分级隔离维护。

到此,相信大家对“怎么为ABP框架配置数据库”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯