ABP框架入门踩坑-使用MySQL

使用MySQL

ABP踩坑记录-目录

起因

因为我自用的服务器只是腾讯云1核1G的学生机,不方便装SQL Server,所以转而MySQL。

这里使用的MySQL版本号为 8.0。

解决方案

  1. 删除Qincai.EntityFrameCore项目中现有的针对SQL Server的迁移文件,即Migrations文件夹。

  2. Qincai.EntityFrameCore项目,添加Pomelo.EntityFrameworkCore.MySqlNuGet引用,并删除对Microsoft.EntityFrameworkCore.SqlServer的引用。

    Orcale官方也有提供MySql.Data.EntityFrameworkCore,但在之前我使用的时候(18年10月)还存在一些Bug,不知道现在有没有修复。如果有知道的同学,可以告知我一下。

  3. Qincai.Web.Host项目中的appsettings.json中修改连接字符串。

    修改连接字符串

    例如这里,是我在本地由Docker启动的MySQL。

  4. 找到Qincai.EntityFrameCore项目下的QincaiDbContextConfigurer.cs文件,修改两处注释的地方。

    using System.Data.Common;
    using Microsoft.EntityFrameworkCore;
    
    namespace Qincai.EntityFrameworkCore
    {
        public static class QincaiDbContextConfigurer
        {
            public static void Configure(DbContextOptionsBuilder<QincaiDbContext> builder, string connectionString)
            {
                //builder.UseSqlServer(connectionString);
                builder.UseMySql(connectionString);
            }
    
            public static void Configure(DbContextOptionsBuilder<QincaiDbContext> builder, DbConnection connection)
            {
                //builder.UseSqlServer(connection);
                builder.UseMySql(connection);
            }
        }
    }
    
  5. 如下图添加Migration。
    添加Migration

    这里需要注意的是,默认项目必须修改为Qincai.EntityFrameworkCore项目,并且你解决方案的启动项目需要设置为Qincai.Web.Host项目。

  6. 然后,就正常Update-Database完事了。

经历

最开始,要换数据库嘛,先查了下官网这篇流程,然后其实就差不多了,过程很简单。

而在这过程中,可能大家会看到类似这样的提示。

错误提示

就如同其字面意思,在新版的SDK中已经包含了这些工具。如果觉得看得不爽,在对应的.csproj文件中找到类似下方的代码,删除即可。

<ItemGroup>
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />
</ItemGroup>
posted @ 2019-01-25 16:55  yiluomyt  阅读(894)  评论(0编辑  收藏  举报