- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
当我运行下面提到的代码时,EF 会使用正确的 PersonId
保存 PersonAddress
。我没有将 PersonAddress
实体添加到 Person
实体,尽管我没有这样做,但我的数据库中的记录已正确链接。
我的问题是:EF 是否会自动 添加相关实体,即使我没有指定它所属的实体?如果是这样,这不会导致不需要的实体关系吗?
更新
似乎由于以下原因正确保存了实体:
Person
时,PersonId
字段为 0PersonAddress.PersonId
在创建时也是 0。通过在创建时手动将 Person.PersonId
设置为任意值,然后将 PersonAddress.PersonId
设置为与 Person.PersonId 相同的值
EF 正确保存数据,因为它们共享相同的 PersonId
。
因此从技术上讲,EF 不会自动添加相关实体,它们是相关的,因为它们共享相同的 PersonId
。
引用以下代码:
using (var context = new Models.TestEntities())
{
var person = context.People.Create();
var postalAddress = context.PersonAddresses.Create();
postalAddress.AddressLine1 = "PostalAddressLine1";
var residentialAddress = context.PersonAddresses.Create();
residentialAddress.AddressLine1 = "ResidentialAddressLine1";
context.People.Add(person);
context.PersonAddresses.Add(postalAddress);
context.PersonAddresses.Add(residentialAddress);
context.SaveChanges();
}
当我在代码中添加额外的 Person
时,出现以下错误:
代码:
using (var context = new Models.TestEntities())
{
var person = context.People.Create();
var person2 = context.People.Create();
var postalAddress = context.PersonAddresses.Create();
postalAddress.AddressLine1 = "PostalAddressLine1";
var residentialAddress = context.PersonAddresses.Create();
residentialAddress.AddressLine1 = "ResidentialAddressLine1";
context.People.Add(person);
context.People.Add(person2);
context.PersonAddresses.Add(postalAddress);
context.PersonAddresses.Add(residentialAddress);
context.SaveChanges();
}
由于指定的错误,Entityframework 现在无法确定 PersonAddress
实体属于谁。
我可以通过如下修改代码来解决这个问题:
using (var context = new Models.TestEntities())
{
var person = context.People.Create();
var person2 = context.People.Create();
var postalAddress = context.PersonAddresses.Create();
postalAddress.AddressLine1 = "PostalAddressLine1";
var residentialAddress = context.PersonAddresses.Create();
residentialAddress.AddressLine1 = "ResidentialAddressLine1";
context.People.Add(person);
context.People.Add(person2);
person.PersonAddresses.Add(residentialAddress);
person.PersonAddresses.Add(postalAddress);
context.SaveChanges();
}
请参阅下面的 EDMX:
请参阅用于创建两个表的 SQL 脚本:
CREATE TABLE Person
(
PersonId INT IDENTITY(1,1) NOT NULL CONSTRAINT [PK_Person] PRIMARY KEY,
FirstName VARCHAR(250)
)
CREATE TABLE PersonAddress
(
PersonAddressId INT IDENTITY(1,1) NOT NULL CONSTRAINT [PK_PersonAddress] PRIMARY KEY,
PersonId INT NOT NULL,
AddressLine1 VARCHAR(250)
)
ALTER TABLE PersonAddress
ADD CONSTRAINT [FK_PersonAddress_Person] FOREIGN KEY(PersonId)
REFERENCES [Person](PersonId)
请参阅下面的 Id 列屏幕截图:
请查看下面的 SQL Server Profiler 跟踪:
人物
:
个人地址
:
个人地址
:
请在SQL中查看插入的记录:
人物
:
个人地址
:
谢谢。
最佳答案
var person = context.People.Create();
Person
被创建时 PersonId
= 0。
var postalAddress = context.PersonAddresses.Create();
postalAddress.AddressLine1 = "PostalAddressLine1";
var residentialAddress = context.PersonAddresses.Create();
residentialAddress.AddressLine1 = "ResidentialAddressLine1";
地址已创建,同时 PersonId
= 0。
context.People.Add(person);
context.PersonAddresses.Add(postalAddress);
context.PersonAddresses.Add(residentialAddress);
EF 已执行关系修复,即它已匹配地址的 PersonId
和 Person
的 PersonId
(全为0)并在它们之间建立关联。
context.SaveChanges();
数据库已将标识值分配给 Person.PersonId
。 EF 将其从数据库读回实体。
在第二个片段中,有两个 Person
的 PersonId
= 0,因此现在 EF 不知道将地址与哪个人相关联。
显然,这是意外行为。最好的办法是明确关联实体,如果它们打算相关,就像在您的第三个代码段中一样。
一旦您了解了这些自动关联,您可能希望通过为 Person.PersonId
分配一个不同于 0 的默认值来阻止它们,例如-1。现在 EF 不会将此 ID 与具有整数默认值 0 的任何其他外部值相匹配。
关于c# - Entityframework 是否在创建时自动分配导航属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29511866/
全部: 我们使用 ASP.NET Web 窗体开始了我们的项目。 我们的 ASP.NET C# web 应用程序在以下环境中使用 .NET Framework 4 ASP.NET Web Forms.
我在尝试为 Entity Framework Core 添加迁移到 Code First 项目时遇到错误,这里是详细信息... 我创建了一个新的 ASP.Net Core Web 项目(VS 2017
Error 1 Copying file bin\EntityFramework.SqlServer.xml to obj\Debug\Package\PackageTmp\bin\Entit
我有一个WPF应用程序,我使用了MVVM体系结构,数据库sql server compact 4。 首先是Entityframework.sqlserverCompact数据库,我使用了通用存储库模式
例如,将 products.Where(p => p.LastModifiedOn > someDate) 总是以相同的订单返回产品(无论如何订购,只要每次调用相同的代码时都是一致的)?或者我应该添加
好吧,假设我有一个用户表,然后是一个记录所有登录尝试的表(Id(计数器)、userId、时间以及是否成功) 现在在我的实体模型中,我希望它成为 2 个关联的一个,包含所有成功尝试的时间和一个包含所有不
我正在努力处理如何最好地跨多个 Visual Studio 项目分解域模型。我正在使用 EntityFramework 4 和企业类型模式来合理化一个可以重用于各种应用程序的系统。最终我想得到一组可以
是否可以使用 POCO 和 EF 处理以下情况?我想要一个 Vehicles 表,有一些 bool 字段,如 IsFast、IsVan、IsTruck,然后有一个 Vehicles 类,有一个 Fas
当我通过传递比较泛型类型 TId 的谓词调用 DbSet.FirstOrDefault() 时,出现以下异常: unable to create a constant value of type 's
我正在使用 EF5 将一些数据从一个数据库迁移到另一个数据库。我通常会使用 SQL 来做这样的事情,但是我需要其他功能(比如在 MembershipProvider 中创建用户)并且希望在 EF 中完
我创建了一个单独的项目并将我的模型复制到这个项目中。我引用了 using System.ComponentModel.DataAnnotations 我的模型定义如下: public class F
上下文: 我有两个类在 SQL 中有两个对应的表。 系统信息 EF 版本: SQL 版本:2012 类 public class Employee { public Employee(
我有一个定义了主从关系的 Entity Framework 对象。详细信息对象集合有一个导航属性。 在稍后的代码中,我尝试使用 AutoMapper 将其中一个主对象映射到数据传输对象。但是,数据传输
有没有办法让这个通用 Context.SalesEntity.Where(t=>t.id==3).Delete(); 有点像 private void DoWork(Expression> predi
来自 NHibernate 背景 - 我有一些审计列来反射(reflect)谁最后编辑了一条记录,以及该编辑发生的时间。 我已经覆盖了 SaveChanges 以寻找一个公共(public)基类,并使
我是 EntityFramework 6 的新手,一直在 POCO 中遇到问题。 以下是我的代码 Domain.cs public abstract class BaseEntity { [K
我刚在单元测试项目中遇到一个问题,坚持认为它需要 EntityFramework 的引用,我确信它不需要它。其他项目正在引用单元测试项目正在引用/测试的项目/扩展方法,并且在不引用 EntityFra
下面的代码应该做什么?在此代码中添加包含表的目的是什么,它应该对与 PersonId 相关的 JobType 进行级联删除,还是只删除具有指定 PersonId 的 Person ? db.tblPe
我试图了解延迟加载在 Entity Framework 6 中是如何工作的。在我看来,延迟加载只适用于 DbContext,其中“to-be-loaded”属性已经存在访问过。请查看下面的示例 - 测
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Entity Framework Validation EntityFramework有什么好的灵活的验证框
我是一名优秀的程序员,十分优秀!