EntityFrameworkCore入门

EntityFrameworkCore操作本地数据库SQLite

Entity Framework Core是.NET平台上的开源跨平台ORM框架,旨在简化.NET数据访问。

  1. 安装数据库句柄,使用NuGet安装Microsoft.EntityFrameworkCore.Sqlite

同时会安装依赖文件Microsoft.EntityFrameworkCore核心包。

  1. 安装数据库迁移工具Microsoft.EntityFrameworkCore.Tools

  1. 新建一个类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 指定StudentBook是一对多的关系,并且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也会被加载。

删除ID2Student

修改ID2Student

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值