前言:
用到的迁移命令:
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,配置Https要和不要都可以,其他默认,然后点击创建
文章图片
创建完成后是这样的
文章图片
二 创建准备迁移的表 右键添加文件夹,创建一个Context的文件夹,用于存放创建表的类
文章图片
文章图片
右键依赖项,点击管理NuGet程序包,搜索安装Pomelo.EntityFrameworkCore.MySql
文章图片
文章图片
在Context文件夹创建City类
文章图片
文章图片
类定义几个变量,也就是迁移到数据库的字段
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类,用于绑定上下文
文章图片
DemoContext类内容,记住要继承DbContext类
using Microsoft.EntityFrameworkCore;
namespace WebApplication1.Context
{
public class DemoContext : DbContext
{
//添加City类
public DbSet Cities { get;
set;
}
//构造函数
public DemoContext(DbContextOptions 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;
"
}
文章图片
在NuGet程序包上搜索安装下面这两个包,Microsoft.EntityFrameworkCore.Tools
Microsoft.EntityFrameworkCore.Design
用于迁移基本迁移命令在Microsoft.EntityFrameworkCore.Tools描述下就有
文章图片
在Program.cs配置添加注入下面代码
builder.Services.AddDbContext(option =>
{
string DbConnectionString = builder.Configuration.GetConnectionString("DbConnectionString");
option.UseMySql(DbConnectionString, new MySqlServerVersion(new Version(8, 0, 11)));
});
文章图片
开始迁移,点击工具,NuGet包管理器,程序包管理器控制台,打开控制台
文章图片
生成迁移文件,在控制台输入 Add-Migration test 生成迁移文件命令,test是迁移文件名称,
然后回车
文章图片
生成的迁移文件
文章图片
迁移更新到数据库,在刚才的控制台输入Update-Database
文章图片
回车确认
文章图片
查看数据库,有表有库,字段一样,迁移成功
文章图片
【C#|从零开始手把手教你,.net 6用EF Core基本创建表,迁移到mysql数据库】下篇我们來学习.net 6框架下的EF Core操作数据库基本增删改查
推荐阅读
- 数据库|安装sql server走过的弯路,收集了一些安装sql遇到的问题
- C#|C# - 环境
- .NET|EF Core codefirst数据迁移操作
- c#|C# 操作Windows注册表
- 深入理解MySql——查询性能优化
- 数据库|从 SQL Server 到 MySQL (一)(异构数据库迁移)
- mysql|7、mysql的redo log、bin log日志
- 网络安全|SQL注入攻击详解
- .NET开发者们,期待你们来发声