从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库

前言:

用到的迁移命令:
Add-Migration test 生成迁移文件命令,test是迁移文件名称
Update-Database 迁移更新到数据库
用到的NuGet包
用于绑定上下文::DbContext
Pomelo.EntityFrameworkCore.MySql
用于迁移
Microsoft.EntityFrameworkCore.Design
Microsoft.EntityFrameworkCore.Tools

一 创建web api项目

选择asp.net core web api项目下一步
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第1张图片框架选择.net 6,配置Https要和不要都可以,其他默认,然后点击创建
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第2张图片
创建完成后是这样的
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第3张图片

二 创建准备迁移的表

右键添加文件夹,创建一个Context的文件夹,用于存放创建表的类
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第4张图片
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第5张图片
右键依赖项,点击管理NuGet程序包,搜索安装Pomelo.EntityFrameworkCore.MySql从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第6张图片
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第7张图片
在Context文件夹创建City类
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第8张图片
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第9张图片
类定义几个变量,也就是迁移到数据库的字段

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;

namespace WebApplication1.Context
{
    public class City
    {
        [Key]
        public int Id { get; set; }
        [Column(TypeName = "nvarchar(100)")]
        public string Name { get; set; }

        [Column(TypeName = "nvarchar(100)")]
        public string AreaCode { get; set; }
    }
}


同样在当前Context文件夹创建DemoContext类,用于绑定上下文
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第10张图片
DemoContext类内容,记住要继承DbContext类

using Microsoft.EntityFrameworkCore;

namespace WebApplication1.Context
{
    public class DemoContext : DbContext
    {
		//添加City类
        public DbSet<City> Cities { get; set; }
        //构造函数
        public DemoContext(DbContextOptions<DemoContext> option) : base(option)
        {

        }
 
    }
}

三 开始迁移

在appsettings.json添加字符串连接串,记得要修改Source:数据库连接地址,Database:数据库名称,User ID:用户名;Password:密码,port:端口号,改成你自己数据库的配置

"ConnectionStrings": {
    "DbConnectionString": " Data Source=localhost;Database=efcodetest;AllowLoadLocalInfile=true;User ID=root;Password=123456;allowPublicKeyRetrieval=true;pooling=true;CharSet=utf8;port=3306;sslmode=none;"
  }

从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第11张图片
在NuGet程序包上搜索安装下面这两个包,Microsoft.EntityFrameworkCore.Tools
Microsoft.EntityFrameworkCore.Design
用于迁移基本迁移命令在Microsoft.EntityFrameworkCore.Tools描述下就有
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第12张图片
在Program.cs配置添加注入下面代码

builder.Services.AddDbContext<DemoContext>(option =>
{
    string DbConnectionString = builder.Configuration.GetConnectionString("DbConnectionString");
    option.UseMySql(DbConnectionString, new MySqlServerVersion(new Version(8, 0, 11)));
});

从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第13张图片
开始迁移,点击工具,NuGet包管理器,程序包管理器控制台,打开控制台
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第14张图片
生成迁移文件,在控制台输入 Add-Migration test 生成迁移文件命令,test是迁移文件名称,
然后回车
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第15张图片
生成的迁移文件
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第16张图片
迁移更新到数据库,在刚才的控制台输入Update-Database
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第17张图片
回车确认
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第18张图片

查看数据库,有表有库,字段一样,迁移成功
从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库_第19张图片

下篇我们來学习.net 6框架下的EF Core操作数据库基本增删改查

你可能感兴趣的:(C#,sql,.net,core,c#,.netcore,mysql)