我是实体框架代码优先的新手。这是我在 ASP.NET MVC 中的学习,使用代码优先创建数据库。
我有两节课:
public class Student
{
public int StudentId { get; set; }
public string Name { get; set; }
public int Standard { get; set; }
public int SubjectId { get; set; }
[ForeignKey("SubjectId")]
public ICollection<Subject> Subjects { get; set; }
}
public class Subject
{
[Key]
public int SubjectId{ get; set; }
public string SubjectName { get; set; }
}
我正在尝试向表中插入一条Student
记录,该表有一个引用该表Student
的外键。SubjectId
Subject
我正在尝试两种可能的方式:
第一种方法
using(var cxt = new SchoolContext())
{
Subject sub = new Subject() { SubjectId = 202, SubjectName ="Geology" };
Student stu = new Student() { Name = "Riya", SubjectId = 202 };
cxt.Subjects.Add(sub);
cxt.Students.Add(stu);
cxt.SaveChanges();
}
在这里,我创建了一个新Subject
实例,它具有SubjectId=202
. 现在,当我创建Student
对象并将值 202 分配给 时SubjectId
,存在Insert
语句冲突。虽然有Subject
with SubjectId = 202
,那为什么会有插入冲突呢?当我调试时,我看到导航属性Subjects
在这里为空。我不明白这里的重点。
第二种方法:
using( var cxt=new SchoolContext())
{
Student stu = new Student() { Name = "Riya" };
Subject sub = new Subject() { SubjectId = 202, SubjectName = "Geology" };
stu.Subjects.Add(sub);
cxt.Students.Add(stu);
cxt.SaveChanges();
}
但我得到一个空引用异常
对象引用未设置为对象的实例
为什么stu.Subjects
这里是空的?
所以我的问题是:
SubjectId
课堂上是什么Student
意思?即它的价值与什么有关?我们可以显式设置它,如果可以,它会引用Subject
表的主键吗?如果不是,它是否仅用于 EF 代码约定目的?同样:导航属性的作用是什么?为什么它为空,什么时候不为空?
我对导航属性的基本理解是,它是用来让EF判断两个实体之间的关系的。
任何人都可以通过示例澄清一下,我们将不胜感激。