ABP vNext 切换数据库为 MySQL

基于启动模板创建的 ABP 项目,默认数据库是 SQLServer,如何切换到 MySQL 呢?下面我来总结一下。

替换包 Volo.Abp.EntityFrameworkCore.SqlServer

.EntityFrameworkCore 引用的 Volo.Abp.EntityFrameworkCore.SqlServer 替换成 Volo.Abp.EntityFrameworkCore.MySQL

替换模块依赖 (Module Dependency)

编辑.EntityFrameworkCore项目里的 xxxEntityFrameworkCoreModule.cs

  • using Volo.Abp.EntityFrameworkCore.SqlServer;替换为using Volo.Abp.EntityFrameworkCore.MySQL;
  • DependenOn里的typeof(AbpEntityFrameworkCoreMySQLModule)替换为typeof(AbpEntityFrameworkCoreMySQLModule)

UseMySQL()

查找解决方案中所有的UseSqlServer(),并替换成UseMySql().

修改数据库连接字符串

找到具有appsetings.json并需要连接数据库的项目,将数据库连接字符串修改为符合 MySQL 格式。

可以参考 connectionstrings.com

通常需要修改.DbMigrator.Web项目

修改 Migration DbContext

IdentityServer module 有自己的数据库映射配置,默认使用 SQLServer 作为数据提供者,需要显式指定成 MySQL

在项目.EntityFrameworkCore.DbMigrations里找到 xxxMigrationsDbContext, 修改如下:

builder.ConfigureIdentityServer(options =>
{
		options.DatabaseProvider = EfCoreDatabaseProvider.MySql;
});

重新生成迁移

  1. 删除.EntityFrameworkCore.DbMigrations项目下的Migrations文件夹,并重新生成解决方案
  2. 在命令行下切换到.Web项目目录,执行命令类似如下:
dotnet ef migrations add 'InitialCreate' 
					--project ../LearnAbp.BookStore.EntityFrameworkCore.DbMigrations  
  1. 执行数据库迁移
dotnet ef database update 
				--project ../LearnAbp.BookStore.EntityFrameworkCore.DbMigrations
  1. 运行.DbMigrator程序初始种子数据

启动程序

到此数据提供程序就完全切换成 MySQL ,可以启动.Web项目查看效果。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值