網站首頁 編程語言 正文
在?AbpBase.Database
?中,通過 Nuget 添加以下幾個庫:
版本都是 1.9.0-preview0917,你可以使用最新版本的。
Freesql FreeSql.Provider.Sqlite FreeSql.Provider.SqlServer FreeSql.Provider.MySql
創建標準的 EFCore 數據庫上下文
在 ABP 中,EFCore 上下文類需要繼承?AbpDbContext
,整體編寫方法跟繼承?DbContext
?一致 ,接下來我們將一步步來講解在?AbpBase
?中如何添加 EFCore 功能。
連接字符串
ABP 中,可以在上下文類加上一個?ConnectionStringName
?特性,然后在配置服務時,ABP 會自動為其配置連接字符串。
[ConnectionStringName("Default")] public partial class DatabaseContext : AbpDbContext
Default
?是一個標識,你也可以填寫其他字符串標識。
定義隔離的上下文
首先,我們在?AbpBase.Database
?模塊中,創建兩個文件夾:
BaseData ExtensionData
BaseData
?目錄用來存放基礎表結構的上下文,ExtensionData
?用來存放可能會拓展或者經常變動的表結構。
在 BaseData 中創建一個?AbpBaseDataContext
?類,其內容如下:
using Microsoft.EntityFrameworkCore; using Volo.Abp.Data; using Volo.Abp.EntityFrameworkCore; namespace AbpBase.Database { ////// 上下文 /// [ConnectionStringName("Default")] public partial class AbpBaseDataContext : AbpDbContext { #region 定義 DbSet這部分用于定義和配置基礎表的映射 ///#endregion public AbpBaseDataContext(DbContextOptions options) : base(options) { } /// /// 定義映射 /// /// 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#endregion /// /// 定義映射 /// /// 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 { ////// 全局共享內容 /// public static class WholeShared { // 數據庫連接屬性可以自行在配置文件中定義,這里寫固定的,只是為了演示 ////// 數據庫連接字符串 /// public static readonly string SqlConnectString = ""; ////// 要使用的數據庫類型 /// public static readonly AbpBaseDataType DataType = AbpBaseDataType.Sqlite; } }
然后我們在?AbpBaseDatabaseModule
?模塊中的?ConfigureServices
?函數里面添加依賴注入:
context.Services.AddAbpDbContext();
這里不需要配置數據庫連接字符串,后面可以通過 ABP 的一些方法來配置。
配置上下文連接字符串
string connectString = default; Configure(options => { connectString = WholeShared.SqlConnectString; options.ConnectionStrings.Default = connectString; });
配置多數據庫支持:
FreeSql.DataType dataType = default; Configure(options => { switch (WholeShared.DataType) { case AbpBaseDataType.Sqlite: options.UseSqlite (); dataType = FreeSql.DataType.Sqlite; break; case AbpBaseDataType.Mysql: options.UseMySQL (); dataType = FreeSql.DataType.MySql; break; case AbpBaseDataType.Sqlserver: options.UseSqlServer (); 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 { ////// Freesql 上下文 /// 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); } ////// 同步結構到數據中 /// /// 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,并且將將表分級隔離維護。
原文鏈接:https://www.cnblogs.com/whuanle/p/13680005.html
相關推薦
- 2023-02-06 Python?PyQt拖動控件對齊到網格的方法步驟_python
- 2022-04-21 Python的基礎語法和輸入輸出函數你都了解嗎_python
- 2022-10-16 Django完整增刪改查系統實例代碼_python
- 2022-06-16 利用Jetpack?Compose實現繪制五角星效果_Android
- 2022-01-11 for循環調用接口返回的數據放在同一個列表中
- 2022-12-21 PyGame實現初始化導入所有模塊方法詳解_python
- 2022-10-10 NumPy?數組屬性的具體使用_python
- 2022-08-26 C++超集C++/CLI模塊的基本語法_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支