零基础开发 WEB 应用:基于 ASP.NET Core MVC 的竞赛管理系统实践04(附源码)

一、利用Deepseek指导开发

通过前面几节我们已经搭建了项目的基本框架,前实现了一些简单的页面,但做为信息管理系统,我们还要搭建数据库环境来管理数据,现在我们就利用AI来指导我们推进吧。

1.AI提示词

给Deepseek表述我们的意图:在输入提示词的同时把我们的母版页提交给AI,让它生成的前端风格能够更充分利用我们之前搭建的环境。
AI提示词

2.AI推理结果

Deepseek推理后给出详细的解决方案:
请添加图片描述

二、开发实践

参照AI给出的方案,我们进行实践吧。

1.配置SQLite数据库

1.安装必要的NuGet包

在项目目录打开终端,并执行如下命令:

dotnet add package Microsoft.EntityFrameworkCore.Sqlite
dotnet add package Microsoft.AspNetCore.Identity.EntityFrameworkCore --version 8.0.0
dotnet add package Microsoft.EntityFrameworkCore.Design

安装NuGet
Microsoft.EntityFrameworkCore.Sqlite是一个包含Sqlite数据库的EF Core框架包。
Microsoft.AspNetCore.Identity.EntityFrameworkCore将 ASP.NET Core Identity 与 Entity Framework Core 集成,提供用于管理用户、角色和其他身份验证相关数据的默认实现。
Microsoft.EntityFrameworkCore.Design用于生成迁移文件将模型类映射到数据库表。

2.已安装 EF Core 工具

Entity Framework (EF) Core 工具是一组命令行工具,用于简化数据库操作和实体模型的管理。它们是 Entity Framework Core (EF Core) 数据访问技术的重要组成部分,主要用于自动化数据库迁移、生成实体类以及与数据库交互等任务。
在项目目录打开终端,并执行如下命令:

dotnet tool install --global dotnet-ef

2.创建数据模型和DbContext

1.在项目中创建Models文件夹,添加School.cs

public class School
{
   
    public Guid Id {
    get; set; }
    
    [Required]
    [Display(Name = "学校名称")]
    public string Name {
    get; set; }
    
    [Display(Name = "学校地址")]
    public string? Address {
    get; set; }
    
    [Display(Name = "成立时间")]
    public DateTime EstablishedDate {
    get; set; }
}

请添加图片描述

2.创建Data/ApplicationDbContext.cs

  • 在项目添加文件夹Data,并在其中创建类:ApplicationDbContext.cs
public class ApplicationDbContext : IdentityDbContext
{
   
	public DbSet<School> Schools {
    get; set; }
}

请添加图片描述

  • 设置数据库文件存储路径
    可以通过重写OnConfiguring方法将数据文件存储在Data文件夹中,代码如下:
    public class ApplicationDbContext : IdentityDbContext
    {
   
        protected override void OnConfiguring(DbContextOptionsBuilder options)
        {
   
            options.UseSqlite("FileName=Data/StudentSys.db");
        }

        public DbSet<School> Schools {
    get; set; }

    }

3.创建数据库迁移

1.第一步

在当前项目文件夹中打开终端。
输入以下命令并回车:

dotnet ef migrations add InitialCreate
  • 命令详解:
    dotnet ef migrations add InitialCreate
    作用:生成一个新的数据库迁移文件,记录当前数据库模型(DbContext)的状态,它将根据模型类创建数据库表。
    参数说明:
    InitialCreate:迁移的名称,通常用于标识首次创建数据库的操作。
    执行过程:
    EF Core 会比较当前 ApplicationDbContext 定义的模型(如实体类、关系)与数据库快照(Snapshot)的差异。
    生成迁移文件(位于 Migrations 文件夹),包含:
    [Timestamp]_InitialCreate.cs:包含 Up()(应用迁移)和 Down()(回滚迁移)方法。
    [Timestamp]_InitialCreate.Designer.cs:元数据文件,记录模型快照。
    更新 Migrations/[YourDbContextModelSnapshot].cs 文件,记录当前模型状态。
  • 验证
    如果终端中显示以下信息,则说明迁移成功
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值