為ABP框架配置數(shù)據(jù)庫(kù)
在 AbpBase.Database 中,通過(guò) Nuget 添加以下幾個(gè)庫(kù):
版本都是 1.9.0-preview0917,你可以使用最新版本的。
Freesql FreeSql.Provider.Sqlite FreeSql.Provider.SqlServer FreeSql.Provider.MySql
創(chuàng)建標(biāo)準(zhǔn)的 EFCore 數(shù)據(jù)庫(kù)上下文
在 ABP 中,EFCore 上下文類(lèi)需要繼承 AbpDbContext<T>,整體編寫(xiě)方法跟繼承 DbContext<T> 一致 ,接下來(lái)我們將一步步來(lái)講解在 AbpBase 中如何添加 EFCore 功能。
連接字符串
ABP 中,可以在上下文類(lèi)加上一個(gè) ConnectionStringName 特性,然后在配置服務(wù)時(shí),ABP 會(huì)自動(dòng)為其配置連接字符串。
[ConnectionStringName("Default")]
public partial class DatabaseContext : AbpDbContext<DatabaseContext>Default 是一個(gè)標(biāo)識(shí),你也可以填寫(xiě)其他字符串標(biāo)識(shí)。
定義隔離的上下文
首先,我們?cè)?nbsp;AbpBase.Database 模塊中,創(chuàng)建兩個(gè)文件夾:
BaseData ExtensionData
BaseData 目錄用來(lái)存放基礎(chǔ)表結(jié)構(gòu)的上下文,ExtensionData 用來(lái)存放可能會(huì)拓展或者經(jīng)常變動(dòng)的表結(jié)構(gòu)。
在 BaseData 中創(chuàng)建一個(gè) AbpBaseDataContext 類(lèi),其內(nèi)容如下:
using Microsoft.EntityFrameworkCore;
using Volo.Abp.Data;
using Volo.Abp.EntityFrameworkCore;
namespace AbpBase.Database
{
/// <summary>
/// 上下文
/// <para>這部分用于定義和配置基礎(chǔ)表的映射</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 中也創(chuàng)建一個(gè)相同的 AbpBaseDataContext 類(lèi),其內(nèi)容如下:
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)
{
}
}
}分部類(lèi),前者用于定義那些非?;A(chǔ)的,程序核心的實(shí)體(表)以及映射。而后者定義后續(xù)可能多次修改的,設(shè)計(jì)時(shí)感覺(jué)有設(shè)計(jì)余地的。
多數(shù)據(jù)庫(kù)支持和配置
這里我們將對(duì)上下文進(jìn)行配置和注入,使得程序能夠支持多數(shù)據(jù)庫(kù)。
在 AbpBase.Domain.Shared 項(xiàng)目中,創(chuàng)建一個(gè)枚舉,其內(nèi)容如下:
namespace AbpBase.Domain.Shared
{
public enum AbpBaseDataType
{
Sqlite = 0,
Mysql = 1,
Sqlserver = 2
// 其他數(shù)據(jù)庫(kù)
}
}再創(chuàng)建一個(gè) WholeShared 類(lèi),其內(nèi)容如下:
namespace AbpBase.Domain.Shared
{
/// <summary>
/// 全局共享內(nèi)容
/// </summary>
public static class WholeShared
{
// 數(shù)據(jù)庫(kù)連接屬性可以自行在配置文件中定義,這里寫(xiě)固定的,只是為了演示
/// <summary>
/// 數(shù)據(jù)庫(kù)連接字符串
/// </summary>
public static readonly string SqlConnectString = "";
/// <summary>
/// 要使用的數(shù)據(jù)庫(kù)類(lèi)型
/// </summary>
public static readonly AbpBaseDataType DataType = AbpBaseDataType.Sqlite;
}
}然后我們?cè)?nbsp;AbpBaseDatabaseModule 模塊中的 ConfigureServices 函數(shù)里面添加依賴(lài)注入:
context.Services.AddAbpDbContext<AbpBaseDataContext>();
這里不需要配置數(shù)據(jù)庫(kù)連接字符串,后面可以通過(guò) ABP 的一些方法來(lái)配置。
配置上下文連接字符串
string connectString = default;
Configure<AbpDbConnectionOptions>(options =>
{
connectString = WholeShared.SqlConnectString;
options.ConnectionStrings.Default = connectString;
});配置多數(shù)據(jù)庫(kù)支持:
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;
}
});這樣就完成了對(duì) EFCore 的多數(shù)據(jù)庫(kù)配置了。
下面我們來(lái)使用類(lèi)似的方法配置 Freesql。
Freesql 配置服務(wù)
首先,F(xiàn)reesql 里面有多種配置方式,例如 DbContext,讀者可以到 Wiki 去學(xué)習(xí) Freesql:
https://github.com/dotnetcore/FreeSql/wiki/%E5%85%A5%E9%97%A8
筆者這里使用的是 “非正規(guī)” 的設(shè)計(jì)方式,哈哈哈哈。
在 BaseData 目錄中,創(chuàng)建一個(gè) FreesqlContext 類(lèi),其內(nèi)容如下:
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) // 自動(dòng)同步實(shí)體結(jié)構(gòu)到數(shù)據(jù)庫(kù),生產(chǎn)環(huán)境禁止使用!
.Build();
OnModelCreating(Freesql_Instance);
}
private static void OnModelCreating(IFreeSql freeSql)
{
OnModelCreatingPartial(freeSql);
}
}
}ExtensionData 目錄中,創(chuàng)建 FreesqlContext 類(lèi) 如下:
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>
/// 同步結(jié)構(gòu)到數(shù)據(jù)中
/// </summary>
/// <param name="codeFirst"></param>
private static void SyncStruct(ICodeFirst codeFirst)
{
// codeFirst.SyncStructure(typeof(user));
}
}
}然后在 AbpBaseDatabaseModule 的 ConfigureServices 函數(shù)中添加注入服務(wù):
FreesqlContext.Init(connectString, dataType);
context.Services.AddSingleton(typeof(IFreeSql), FreesqlContext.FreeselInstance);
context.Services.AddTransient(typeof(FreesqlContext), typeof(FreesqlContext));通過(guò)以上步驟,我們的 ABP 就可以支持多數(shù)據(jù)庫(kù)了,EFCore + Freesql,并且將將表分級(jí)隔離維護(hù)。
到此這篇關(guān)于為ABP框架配置數(shù)據(jù)庫(kù)的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ASP.NET web.config 配置節(jié)點(diǎn)詳解
這篇文章主要介紹了ASP.NET web.config 節(jié)點(diǎn)的配置,講解的非常詳細(xì),需要的朋友可以參考下。2016-06-06
.Net結(jié)構(gòu)型設(shè)計(jì)模式之組合模式(Composite)
這篇文章介紹了.Net結(jié)構(gòu)型設(shè)計(jì)模式之組合模式(Composite),文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05
.NET?6中System.Text.Json的七個(gè)特性
這篇文章介紹了.NET?6中System.Text.Json的七個(gè)特性,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-01-01
Blazor實(shí)現(xiàn)數(shù)據(jù)驗(yàn)證
這篇文章介紹了Blazor實(shí)現(xiàn)數(shù)據(jù)驗(yàn)證的方式,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-01-01
WPF使用ValidationRules對(duì)MVVM架構(gòu)數(shù)據(jù)驗(yàn)證
這篇文章介紹了WPF使用ValidationRules對(duì)MVVM架構(gòu)數(shù)據(jù)驗(yàn)證的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-01-01
ASP.NET MVC把數(shù)據(jù)庫(kù)中枚舉項(xiàng)的數(shù)字轉(zhuǎn)換成文字
這篇文章介紹了ASP.NET MVC把數(shù)據(jù)庫(kù)中枚舉項(xiàng)的數(shù)字轉(zhuǎn)換成文字的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-10-10
一步步打造漂亮的新聞列表(無(wú)刷新分頁(yè)、內(nèi)容預(yù)覽)第二步
由于我們僅僅是項(xiàng)目中的一個(gè)小部分,但也差不多按照以上的順序進(jìn)行開(kāi)發(fā),這是一個(gè)良好的習(xí)慣。我們將概要設(shè)計(jì)和詳細(xì)設(shè)計(jì)放在一起。2010-07-07
.Net行為型設(shè)計(jì)模式之命令模式(Command)
這篇文章介紹了.Net行為型設(shè)計(jì)模式之命令模式(Command),文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05

