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

25 篇文章 7 订阅
6 篇文章 0 订阅

前言:

用到的迁移命令:
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<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;"
  }

在这里插入图片描述
在NuGet程序包上搜索安装下面这两个包,Microsoft.EntityFrameworkCore.Tools
Microsoft.EntityFrameworkCore.Design
用于迁移基本迁移命令在Microsoft.EntityFrameworkCore.Tools描述下就有
在这里插入图片描述
在Program.cs配置添加注入下面代码

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

在这里插入图片描述
开始迁移,点击工具,NuGet包管理器,程序包管理器控制台,打开控制台
在这里插入图片描述
生成迁移文件,在控制台输入 Add-Migration test 生成迁移文件命令,test是迁移文件名称,
然后回车
在这里插入图片描述
生成的迁移文件
在这里插入图片描述
迁移更新到数据库,在刚才的控制台输入Update-Database
在这里插入图片描述
回车确认
在这里插入图片描述

查看数据库,有表有库,字段一样,迁移成功
在这里插入图片描述

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

  • 7
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值