EntityFrameworkCore操作本地数据库SQLite
Entity Framework Core是.NET平台上的开源跨平台ORM框架,旨在简化.NET数据访问。
- 安装数据库句柄,使用NuGet安装Microsoft.EntityFrameworkCore.Sqlite
同时会安装依赖文件Microsoft.EntityFrameworkCore核心包。
- 安装数据库迁移工具Microsoft.EntityFrameworkCore.Tools
- 新建一个类SchoolDBContext,继承DbContext。
using EFCoreSqlite.Models;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace EFCoreSqlite.DBServer
{
class SchoolDBContext: DbContext
{
public DbSet<Student> Students { get; set; }
public DbSet<Book> Books { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Book>()
.HasOne(p => p.Stu)
.WithMany(b => b.Books)
.HasForeignKey(p => p.StudentId);
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
string DBPath = Path.Combine(Directory.GetCurrentDirectory(), "school.db");
optionsBuilder.UseSqlite($"Data Source={DBPath}");
}
}
}
EF Core还支持通过Fluent API来定义更复杂的映射关系,开发者可以在DbContext的子类中配置模型,从而提供比数据注解更为强大和灵活的配置方式。例如,可以指定复合主键、配置一对一关系以及设置索引等高级映射关系。
在代码中通过Fluent API 指定Student和Book是一对多的关系,并且Book里面的StudentId是外键
Student类
其中[Table("T_Student")]是指定生成的表名,如果不指定就以SchoolDBContext中的
public DbSet<Student> Students { get; set; } Students作为表名。
Book.cs
数据库迁移Microsoft.EntityFrameworkCore.Tools
EF Core 提供了强大的迁移功能,允许你将 C# 模型同步到数据库中。
打开程序包管理控制台
添加新的迁移命令, Add-Migration InitialCreate, InitialCreate可以根据情况自定义
更新数据库:Update-Database
本地生成数据库
设置复制属性为始终复制,这样DB文件就拷贝到bin运行目录下面
查看表
添加一个Student
获取数据
查询学生时与之关联的Bool也会被加载。
删除ID为2的Student
修改ID为2的Student