WebApi EF Core 2.1 Code First 设置导航属性,外键
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 设置导航属性,外键的更多相关文章
- .net core webapi+EF Core
.net core webapi+EF Core 一.描述: EF Core必须下载.net core2.0版本 Micorsoft.EntityFrameworkCore:EF框架的核心包Micor ...
- EF Core中如何正确地设置两张表之间的关联关系
数据库 假设现在我们在SQL Server数据库中有下面两张表: Person表,代表的是一个人: CREATE TABLE [dbo].[Person]( ,) NOT NULL, ) NULL, ...
- EF如何操作内存中的数据和加载外键数据:延迟加载、贪婪加载、显示加载
EF如何操作内存中的数据和加载外键数据:延迟加载.贪婪加载.显示加载 之前的EF Code First系列讲了那么多如何配置实体和数据库表的关系,显然配置只是辅助,使用EF操作数据库才是每天开发中都需 ...
- [翻译 EF Core in Action 2.1] 设置一个图书销售网站的场景
Entity Framework Core in Action Entityframework Core in action是 Jon P smith 所著的关于Entityframework Cor ...
- 【.Net Core 学习系列】-- EF Core 实践(Code First)
一.开发环境: VS2015, .Net Core 1.0.0-preview2-003156 二解决方案: 新建项目: File --> New --> Project --> ...
- EF Code First中的主外键约定和一对一、一对多关系的实现
对于主外键约定的理解,其实是学习实体间一对一和一对多关系的基础. 1.1 主键(Key)约定 主键的默认约定是:只要字段名为--实体名(类名)+"id"(不区分大小写),这就算是默 ...
- ef core中使用code first
这个配置还是挺坑,照这个一步步做倒是可以 https://www.cnblogs.com/chenzhaoyu/p/7831980.html
- 【.Net 学习系列】-- EF Core实践(Code First)
一.开发环境: vs2015, .Net Framework 4.6.1 二.解决方案: 新建一个控制台应用程序 添加引用:Microsoft.EntityFrameworkCore.SqlServe ...
- ef core 数据类型 && 表字段名设置
HasColumnType HasColumnType是指定字段类型 [Column(TypeName = "decimal(18, 2)")] public decimal Mo ...
- C# 数据操作系列 - 8. EF Core的增删改查
0.前言 到目前为止,我们看了一下如何声明EF Core的初步使用,也整体的看了下EF Core的映射关系配置以及导航属性的配置. 这一篇,我带大家分享一下,我在工作中需要的EF Core的用法. 1 ...
随机推荐
- Git提交代码报错husky > pre-commit,
拉取了新项目以后,git突然不能用了 报husky > pre-commit, 解决办法:进入你的项目显示隐藏git文件 进入git文件 找到 hooks / pre-commit ...
- 四种语言刷算法之47. 全排列 II
47. 全排列 II 1.C /** * Return an array of arrays of size *returnSize. * The sizes of the arrays are re ...
- py2exe打包datatable程序后运行时提示No module named 'datatable.utils'
把setup.py的代码更新为如下: setup(console=['test1.py'], options={ 'py2exe':{ 'packages':['datatable.utils'] } ...
- go 程序设计语言 命令行参数
最近打算读一读 go程序设计语言这本书, 读语言类的书是一件十分头疼的事情, 因为读一本书就意味着,看着一堆钳子 锥子工具的图片, 概念背了一大堆,仍然不知道怎么用,还是要通过实践. 还是习惯任务驱动 ...
- element ui中table动态列切换时,表格样式变形
现象:定义多个头部和多个数据体,可以自由切换不同的头部和相应的数据体,但是切换过程表格会变形. 解决办法:table增加索引,切换头部和数据时,修改为不同的索引,即可解决 重点:表格标签上的 key ...
- ElasticSearch、ElasticSearch-head的安装和问题解决
前言:elasticsearch作为一个基于Lucene的分布式搜索引擎,其搜索功能的强大之处不用多说,而elasticsearch-head作为一个node项目,能够轻松管理elasticsearc ...
- Dilworth
Dilworth 定理 偏序集能划分成的最少的全序集个数等于最大反链的大小. 名词解释 偏序 在集合 \(S\) 中定义的二元关系 \(\le\),如果它满足以下三个性质: 自反性:\(\forall ...
- Django里ORM常用关键字
一.ORM常用关键字 # 关键概览 1.create() 2.filter() 3.first() last() 4.update() 5.delete() 6.all() 7.values() 8. ...
- Web安全与渗透测试笔记
Web安全与渗透测试笔记 @author: lamaper 一.基本网络知识 (一)网络是怎样联通的 TCP/IP协议 Internet Http协议 (二)Http协议 http请求 一个完整的Ht ...
- [737] Interlude OpCodez
[737] Interlude Client 00 SendProtocolVersion 01 MoveBackwardToLocation 02 Say 03 RequestEnterWorld ...