Nuget:

Microsoft.AspNetCore.All

Microsoft.EntityFrameworkCore//Include 导航属性在此空间

Microsoft.EntityFrameworkCore.SqlServer

Microsoft.EntityFrameworkCore.Tools

微软懒加载文档:

https://docs.microsoft.com/en-us/ef/core/querying/related-data

注入EF:

        public void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
services.AddDbContext<AppDbContext>(options =>
{
//options.UseSqlServer(Configuration.GetConnectionString("SqlConnection"));
options.UseSqlServer(Configuration["ConnectionStrings:SqlConnection"]);
});
services.AddMvc()
.AddJsonOptions(
options => options.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore
);//设置禁止循环引用
var serviceProvider = services.BuildServiceProvider(); using (var context = serviceProvider.GetService<AppDbContext>())
{
context.Database.Migrate();
}
}

种子数据:

  protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Teacher>().HasMany(x=>x.Students);//设置关系
modelBuilder.Entity<Teacher>().HasData(new List<Teacher>() {
new Teacher() { age=3, id=1, name="T1"}
,new Teacher() { age=3, id=2, name="S2"}
, new Teacher() { age=3, id=3, name="F3"}
, new Teacher() { age=3, id=4, name="D4"}
});
modelBuilder.Entity<Student>().HasOne(c=>c.Teacher);//设置关系
modelBuilder.Entity<Student>().HasData(new List<Student>() {
new Student() { age=3, id=1, name="T" ,TeacherId=2}
,new Student() { age=3, id=2, name="S" ,TeacherId=2}
, new Student() { age=3, id=3, name="F" ,TeacherId=1}
, new Student() { age=3, id=4, name="D" ,TeacherId=3}
});
base.OnModelCreating(modelBuilder);
}

查询:

[HttpGet]
public IEnumerable<object> Get()
{
AppDbContext db = new AppDbContext();
var student = db.Students.Include(x=>x.Teacher).Where(x=>x.id==1).ToList();
var t = db.Teachers.Include(x => x.Students).Where(x=>x.id==2);
return t.ToList();
}

实体:

 public class Student
{
public int id { get; set; }
public int age { get; set; }
public string name { get; set; }
[ForeignKey("Teacher.Id")]//设置外键,表.主键
public int TeacherId { get; set; }
//[JsonIgnore] 禁止序列化JSON
public virtual Teacher Teacher { get; set; } //= new Teacher();
}
public class Teacher
{
public int id { get; set; }
public int age { get; set; }
public string name { get; set; }
//[JsonIgnore] 禁止序列化JSON
public virtual ICollection<Student> Students { get; set; }// = new List<Student>();
}

WebApi EF Core 2.1 Code First 设置导航属性,外键的更多相关文章

  1. .net core webapi+EF Core

    .net core webapi+EF Core 一.描述: EF Core必须下载.net core2.0版本 Micorsoft.EntityFrameworkCore:EF框架的核心包Micor ...

  2. EF Core中如何正确地设置两张表之间的关联关系

    数据库 假设现在我们在SQL Server数据库中有下面两张表: Person表,代表的是一个人: CREATE TABLE [dbo].[Person]( ,) NOT NULL, ) NULL, ...

  3. EF如何操作内存中的数据和加载外键数据:延迟加载、贪婪加载、显示加载

    EF如何操作内存中的数据和加载外键数据:延迟加载.贪婪加载.显示加载 之前的EF Code First系列讲了那么多如何配置实体和数据库表的关系,显然配置只是辅助,使用EF操作数据库才是每天开发中都需 ...

  4. [翻译 EF Core in Action 2.1] 设置一个图书销售网站的场景

    Entity Framework Core in Action Entityframework Core in action是 Jon P smith 所著的关于Entityframework Cor ...

  5. 【.Net Core 学习系列】-- EF Core 实践(Code First)

    一.开发环境: VS2015, .Net Core 1.0.0-preview2-003156 二解决方案: 新建项目: File --> New --> Project -->   ...

  6. EF Code First中的主外键约定和一对一、一对多关系的实现

    对于主外键约定的理解,其实是学习实体间一对一和一对多关系的基础. 1.1 主键(Key)约定 主键的默认约定是:只要字段名为--实体名(类名)+"id"(不区分大小写),这就算是默 ...

  7. ef core中使用code first

    这个配置还是挺坑,照这个一步步做倒是可以 https://www.cnblogs.com/chenzhaoyu/p/7831980.html

  8. 【.Net 学习系列】-- EF Core实践(Code First)

    一.开发环境: vs2015, .Net Framework 4.6.1 二.解决方案: 新建一个控制台应用程序 添加引用:Microsoft.EntityFrameworkCore.SqlServe ...

  9. ef core 数据类型 && 表字段名设置

    HasColumnType HasColumnType是指定字段类型 [Column(TypeName = "decimal(18, 2)")] public decimal Mo ...

  10. C# 数据操作系列 - 8. EF Core的增删改查

    0.前言 到目前为止,我们看了一下如何声明EF Core的初步使用,也整体的看了下EF Core的映射关系配置以及导航属性的配置. 这一篇,我带大家分享一下,我在工作中需要的EF Core的用法. 1 ...

随机推荐

  1. Word19 撰写企业质量管理论文office真题

    1.看到题目要求:打开考试文件下的素材文档"WPS.docx"文件,后续操作均基于此文件,否则不得分. 2.这一步的操作非常简单,打开文件目录进行双击打开即可完成操作. 3.看到题 ...

  2. 【C学习笔记】day4-3 求Sn=a+aa+aaa+aaaa+aaaaa的前5项之和,其中a是一个数字

    求Sn=a+aa+aaa+aaaa+aaaaa的前5项之和,其中a是一个数字, 例如:2+22+222+2222+22222 #include <stdio.h> #include < ...

  3. span&不同字体

    <html> <style> .p1{ color:red; font-size:28px; } .p2{ font-weight:bold; } .p3{ font-styl ...

  4. gitlab-runner运行流水线过程中出现报错

    1.提示error: could not lock config file D:\gitlab-runner\builds\fJW28yU8\0\auto_test_10\auto_test_dp20 ...

  5. spark2.0.1源码编译

    一.编译源码步骤演示详解 . 编译spark环境要求 1.必须在linux系统下编译(以centos6.4为例) 2.编译使用的JDK版本必须是1.6以上(以JDK1.8为例) 3.编译需要使用Mav ...

  6. kafka数据顺序一致

    问题: kafka如何发送顺序消息 方案:kafka可以通过partitionKey,将某类消息写入同一个partition,一个partition只能对应一个消费线程,以保证数据有序. 也就是说生产 ...

  7. springboot集成xxl-job问题

    Client-error:unknown code for readObject at 0x3c (<) 原因之一是classNotFoundRxception :com.caucho.hess ...

  8. JAVA JAR包注册成服务,开机启动,WINSW使用

    1,下载工具 WINSW. https://www.aliyundrive.com/s/fACj3xk8R74 点击链接保存,或者复制本段内容,打开「阿里云盘」APP ,无需下载极速在线查看,视频原画 ...

  9. Redis哨兵模式+缓存穿透、击穿和雪崩

    一.哨兵模式概述(自动选主机的方式)主从切换技术:当主机宕机后,需要手动把一台从(slave)服务器切换为主服务器,这就需要人工干预,费时费力,还回造成一段时间内服务不可用,所以推荐哨兵架构(Sent ...

  10. 如果同时存在application.properties 和application.yml 文件的话,springboot会优先使用application.properties吗

    如果同时存在application.properties 和application.yml 文件的话,springboot会优先使用application.properties吗 总结:如果appli ...