我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么为ABP框架配置数据库

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么为ABP框架配置数据库

本篇内容主要讲解“怎么为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

    怎么为ABP框架配置数据库

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    怎么为ABP框架配置数据库

    本篇内容主要讲解“怎么为ABP框架配置数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么为ABP框架配置数据库”吧!在 AbpBase.Database 中,通过 Nuget 添加以下几个
    2023-06-29

    navicat怎么配置数据库

    navicat 数据库配置步骤:连接到数据库服务器(选择类型、输入连接信息)。创建或选择数据库(展开服务器节点,“创建数据库”或“刷新”)。设置数据库属性(右键单击数据库,“属性”)。创建或修改用户(右键单击数据库,“用户”)。导入或导出数
    navicat怎么配置数据库
    2024-04-24

    安全框架Shiro怎么配置

    这篇文章主要介绍“安全框架Shiro怎么配置”,在日常操作中,相信很多人在安全框架Shiro怎么配置问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”安全框架Shiro怎么配置”的疑惑有所帮助!接下来,请跟着小编
    2023-06-26

    Flutter怎么用ORM框架管理数据库

    本篇内容主要讲解“Flutter怎么用ORM框架管理数据库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Flutter怎么用ORM框架管理数据库”吧!floor 数据库版本升级floor 框架同
    2023-07-06

    odbc怎么配置access数据库

    要配置ODBC连接到Access数据库,你需要按照以下步骤进行操作:1. 打开“控制面板”,然后选择“管理工具”。2. 在“管理工具”窗口中,找到并打开“ODBC数据源(32位)”(如果你的操作系统是64位的,则选择“ODBC数据源(64位
    2023-09-22

    springboot怎么配置双数据库

    在Spring Boot中配置双数据库可以使用多个数据源。可以按照以下步骤进行配置:1. 在application.properties(或application.yml)文件中配置第一个数据源的相关属性:spring.datasource
    2023-10-21

    springboot怎么配置db2数据库

    要在Spring Boot项目中配置DB2数据库,首先需要在application.properties文件中配置数据库连接信息。以下是一个示例配置:spring.datasource.url=jdbc:db2://localhost:5
    springboot怎么配置db2数据库
    2024-04-09

    idea怎么配置mysql数据库

    要配置MySQL数据库,您可以按照以下步骤进行操作:下载并安装MySQL数据库软件:您可以从MySQL官方网站下载MySQL数据库软件,并按照安装指南进行安装。设置数据库管理员账户:在安装完成后,您需要设置数据库管理员账户,包括用户名和密码
    idea怎么配置mysql数据库
    2024-03-05

    C++测试框架GoogleTest怎么配置

    今天小编给大家分享一下C++测试框架GoogleTest怎么配置的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。简单介绍来看看
    2023-07-05

    springboot logback日志框架怎么配置

    本篇内容介绍了“springboot logback日志框架怎么配置”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!logback既可以通过a
    2023-06-30

    SpringMVC框架怎么搭建idea操作数据库

    这篇文章主要介绍“SpringMVC框架怎么搭建idea操作数据库”,在日常操作中,相信很多人在SpringMVC框架怎么搭建idea操作数据库问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SpringMVC
    2023-06-29

    数据库ssl证书怎么配置

    配置数据库的SSL证书需要以下步骤:1. 在数据库服务器上生成SSL证书和密钥文件。可以使用OpenSSL工具来生成证书和密钥文件。可以使用以下命令生成自签名证书:```openssl req -new -x509 -sha256 -nod
    2023-08-15

    oracle数据库监听怎么配置

    要配置Oracle数据库监听器,您需要执行以下步骤:打开监听器配置文件:在Oracle数据库服务器上找到listener.ora文件。该文件通常位于ORACLE_HOME/network/admin目录中。编辑监听器配置文件:使用文本编辑器
    oracle数据库监听怎么配置
    2024-04-09

    springboot怎么配置主从数据库

    在Spring Boot中配置主从数据库可以通过在application.properties文件中配置多个数据源来实现。以下是一个示例配置:1、在application.properties中配置主数据源:spring.datasou
    springboot怎么配置主从数据库
    2024-03-12

    SpringBoot2 中怎么配置MongoDB数据库

    这期内容当中小编将会给大家带来有关SpringBoot2 中怎么配置MongoDB数据库,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。nosql-">一、NoSQL简介1、NoSQL 概念NoSQL( N
    2023-06-02

    tomcat怎么修改数据库配置

    要修改Tomcat的数据库配置,可以按照以下步骤操作:1. 找到Tomcat安装目录下的`conf`文件夹,然后打开`context.xml`文件。2. 在`context.xml`文件中,可以看到以下示例代码:```xml
    2023-08-18

    plsql怎么配置数据库连接

    要配置PL/SQL Developer以连接到数据库,请按照以下步骤操作:打开PL/SQL Developer。单击工具栏中的“连接”按钮或选择“文件”>“连接”菜单项。在“新连接”对话框中,选择“Oracle”作为数据库类型。在“连接”选
    plsql怎么配置数据库连接
    2024-04-09

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录