.Net基础系列(五):初始化数据库中表的数据

问题

如何在.Net项目中初始化数据库的数据?

前置条件

  • 基于.Net 6.0创建的C# Demo
  • 主要目录结构如下
txt 复制代码
DemoApplication
    |---> src
           |---> db
                  |---> DataSeeder.cs
                  |---> SqlDbContext.cs
                  |---> configuration folder
                          |---> BooksEntityConfiguration.cs
           |---> Migrations folder
           |---> Program.cs

通过代码生成数据库表

0. 类之间的依赖关系

flowchart LR A0[Books实体类] --> |被使用| M0[BooksEntityConfiguration.cs] M0 -->|被使用 | A1[SqlDbContext] A1 -->|被使用 | M2[Program.cs]

1. 生成实体Books类的配置文件

创建BooksEntityConfiguration.cs类,继承IEntityTypeConfiguration,参数是Books类。

然后在Configure方法里配置Books数据表的额外属性,如Key是哪个字段,哪个字段什么样是否必须等。 注意这里 ,配置是可以跳过的,那么程序就会按照Books类的定义生成数据表的结构。

C# 复制代码
// BooksEntityConfiguration.cs
public class BooksEntityConfiguration : IEntityTypeConfiguration<Books>
{
    public void Configure(EntityTypeBuilder<Books> builder)
    {
        builder.HasKey(b => b.Id);
        
        builder.Property(b => b.Id).HasDefaultValueSql("NEWID()");
        builder.Property(b => b.Name).IsRequired();
        builder.Property(b => b.AuthorId).IsRequired();
        builder.Property(b => b.CreatedBy).HasColumnType("date");

        builder.HasIndex(b => b.Name).IsUnique();
    }
}

2. 应用Books类的配置

定义SqlDbContext.cs类,继承DbContext,在OnModelCreating方法中应用前面定义的关于Books的配置。

C# 复制代码
// SqlDbContext.cs
public class SqlDbContext : DbContext
{
    public DbSet<Books> Books { get; set; }

    public SqlDbContext(DbContextOptions options) : base(options)
    {
    }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.ApplyConfiguration(new BooksEntityConfiguration());
    }
}

3. 安装并使用dotnet命令生成Migrations文件

  • 安装dotnet工具
sh 复制代码
dotnet tool install --global dotnet-ef
  • 使用dotnet-ef命令,根据配置文件在Migrations目录下生成要迁移的数据文件.
sh 复制代码
dotnet ef migrations add Books --project Demo/Demo.csproj
dotnet ef database update -p Demo/Demo.csproj

4. 基于Migrations文件创建数据库的表

Program.cs 获取到DB的实例,然后执行Migrate方法,执行上一步生成的Migrations文件,在数据库生成需要的数据表。

C# 复制代码
// Program.cs
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();

using (var scope = app.Services.CreateScope())
{
    var services = scope.ServiceProvider;
    var db = services.GetService<SqlDbContext>();
    // 这里
    db.Database.Migrate();
}

初始化数据

0. 类之间的依赖关系

flowchart LR M1[Program.cs] --> |调用|A[Migrate] M1 --> |调用| B[Seed] B --> |调用| B1[DataSeeder]

1. 初始化Books数据

DataSeeder.cs静态类中,配置books列表,然后将这些数据更新到数据库的表中,也可以指定哪些字段不需要更新。

C# 复制代码
// DataSeeder.cs
public static class DataSeeder
{
    public static void SeedData(this SqlDbContext db)
    {
        SeedBooks(db);
    }

    private static void SeedBooks(SqlDbContext db)
    {
        var books = new List<Books>
        {
            new Books { Name = "悉达多", Type = "文学"}
        };

        db.BulkInsertOrUpdate(books, options =>
        {
            options.UpdateByProperties = new List<string> { nameof(Books.Name) };
            options.PropertiesToExcludeOnUpdate = new List<string> { nameof(Books.Id) };
        });
    }

2. 执行

Program.cs 获取到DB的实例,然后在项目开始的时候,初始化数据库中表的数据。这部分由SeedData方法来实现。

C# 复制代码
// Program.cs
var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();

using (var scope = app.Services.CreateScope())
{
    var services = scope.ServiceProvider;
    var db = services.GetService<SqlDbContext>();
    db.Database.Migrate();
    // 这里
    db.SeedData();
}
相关推荐
mudtools3 小时前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
c#·.net
大飞pkz9 小时前
【设计模式】C#反射实现抽象工厂模式
设计模式·c#·抽象工厂模式·c#反射·c#反射实现抽象工厂模式
唐青枫11 小时前
从入门到进阶:C#.NET Stopwatch 计时与性能测量全攻略
c#·.net
私人珍藏库12 小时前
[Windows] 微软 .Net 运行库离线安装包 | Microsoft .Net Packages AIO_v09.09.25
microsoft·.net·运行库
未来之窗软件服务20 小时前
幽冥大陆(二)RDIFSDK 接口文档:布草洗涤厂高效运营的技术桥梁C#—东方仙盟
开发语言·c#·rdif·仙盟创梦ide·东方仙盟
1uther21 小时前
Unity核心概念⑨:Screen
开发语言·游戏·unity·c#·游戏引擎
追逐时光者1 天前
C#/.NET/.NET Core技术前沿周刊 | 第 54 期(2025年9.8-9.14)
后端·.net
追逐时光者1 天前
C#/.NET/.NET Core编程技巧练习集,配套详细的文章教程讲解!
后端·.net
阿幸软件杂货间1 天前
Office转PDF转换器v1.0.py
开发语言·pdf·c#
sali-tec1 天前
C# 基于halcon的视觉工作流-章34-环状测量
开发语言·图像处理·算法·计算机视觉·c#