第四节 利用Deepseek指导开发-配置数据库环境
一、利用Deepseek指导开发
通过前面几节我们已经搭建了项目的基本框架,前实现了一些简单的页面,但做为信息管理系统,我们还要搭建数据库环境来管理数据,现在我们就利用AI来指导我们推进吧。
1.AI提示词
给Deepseek表述我们的意图:在输入提示词的同时把我们的母版页提交给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
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 文件,记录当前模型状态。 - 验证
如果终端中显示以下信息,则说明迁移成功