<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在 AbpBase.Database
中,通過 Nuget 新增以下幾個庫:
版本都是 1.9.0-preview0917,你可以使用最新版本的。
Freesql FreeSql.Provider.Sqlite FreeSql.Provider.SqlServer FreeSql.Provider.MySql
在 ABP 中,EFCore 上下文類需要繼承 AbpDbContext<T>
,整體編寫方法跟繼承 DbContext<T>
一致 ,接下來我們將一步步來講解在 AbpBase
中如何新增 EFCore 功能。
ABP 中,可以在上下文類加上一個 ConnectionStringName
特性,然後在設定服務時,ABP 會自動為其設定連線字串。
[ConnectionStringName("Default")] public partial class DatabaseContext : AbpDbContext<DatabaseContext>
Default
是一個標識,你也可以填寫其他字串標識。
首先,我們在 AbpBase.Database
模組中,建立兩個資料夾:
BaseData ExtensionData
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 裡面有多種設定方式,例如 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框架設定資料庫的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45