- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我看过类似错误的答案,但我似乎无法找到我的特定错误的答案。
我正在运行迁移,运行种子方法时发生错误(迁移工作正常)。
The declared type of navigation property Project.Models.Customer.SubCustomers is not compatible with the result of the specified navigation.
这是为了循环引用,即一个客户可以有 0..* 个子客户和 0..1 个父客户。
客户模型:
public class Customer : Entity
{
public int CustomerId { get; set;}
public string Name { get; set; }
// Relationships
public int? ParentCustomerId { get; set; }
public virtual ICollection<Customer> SubCustomers { get; set; } // a Customer has many Customers as SubCustomers, a Customer has zero or one ParentCustomer
// Other relationships
}
来自上下文流畅的 api:
modelBuilder.Entity<Customer>()
.HasKey(customer => customer.CustomerId);
modelBuilder.Entity<Customer>()
.Property(customer => customer.Name)
.IsRequired()
.HasColumnType("nvarchar")
.HasMaxLength(500);
modelBuilder.Entity<Customer>() // a Customer has many Customers as SubCustomers, a Customer has zero or one ParentCustomer
.HasOptional(customer => customer.SubCustomers)
.WithMany()
.HasForeignKey(customer => customer.ParentCustomerId);
from seed方法:(在数据库中创建客户,子客户不起作用)
// Default Customers - create and save
var customers = new[]{
new Customer { Name = "Custa" },
new Customer { Name = "Custb" },
new Customer { Name = "Custc" }
};
context.Customers.AddOrUpdate(r => r.Name, customers[0], customers[1], customers[2]);
context.SaveChanges();
// Add SubCustomers b & c to Customer a (ids calculated beforehand, e.g. aId, as linq does not support array index)
var aId = customers[0].CustomerId;
var a = context.Customers.Include(c => c.SubCustomers).SingleOrDefault(c => c.CustomerId == aId);
if (a.SubCustomers == null)
a.SubCustomers = new List<Customer>();
var bId = customers[1].CustomerId;
var b = a.SubCustomers.SingleOrDefault(c => c.CustomerId == bId);
if (b == null)
a.SubCustomers.Add(context.Customers.Single(c => c.CustomerId == bId));
var cId = customers[2].CustomerId;
var c = a.SubCustomers.SingleOrDefault(c => c.CustomerId == cId);
if (c == null)
a.SubCustomers.Add(context.Customers.Single(c => c.CustomerId == cId));
context.SaveChanges();
如果有人能找出导致错误的原因,我将不胜感激。非常感谢!
最佳答案
所以经过一些阅读和反复试验,我终于明白了这一点。我感到很困惑,因为它是自引用的,遗漏了一个关键元素。
通常,当在两个不同的对象之间创建一对多关系时,您会得到如下内容:
public class Foo {
public int FooId {get; set;}
public string Name {get; set;}
// Relationships
public virtual ICollection<Bar> Bars {get; set;} // a Foo has many bars, a Bar has one optional Foo
}
public class Bar {
public int BarId {get; set;}
public string Name {get; set;}
// Relationships
public int? FooId {get; set;} // a Foo has many bars, a Bar has one optional Foo
public virtual Foo Foo {get; set;}
}
然后在上下文中(流畅的 API):
modelBuilder.Entity<Bar>() // a Foo has many bars, a Bar has one optional Foo
.HasRequired(bar => bar.Foo)
.WithMany(foo => foo.Bars)
.HasForeignKey(bar => bar.FooId);
modelBuilder.Entity<Bar>()
.HasKey(bar => bar.BarId);
modelBuilder.Entity<Foo>()
.HasKey(foo => foo.FooId);
在我的代码中,在我最初的问题中,我遗漏了 public virtual Foo Foo {get;设置;
在这种情况下。
因此,要创建一个自引用的 Foo,您需要将关系的所有三个元素(在上面的示例中拆分为两个对象)放在 Foo 对象中(真的很合乎逻辑!):
public class Foo {
public int FooId {get; set;}
public string Name {get; set;}
// Relationships
public int? ParentFooId {get; set;} // a Foo has many SubFoos, a Foo has one optional ParentFoo
public virtual Foo ParentFoo {get; set;}
public virtual ICollection<Foo> SubFoos {get; set;}
}
和上下文(流畅的 API):
modelBuilder.Entity<Foo>() // a Foo has many SubFoos, a Foo has one optional ParentFoo
.HasOptional(foo => foo.ParentFoo)
.WithMany(foo => foo.SubFoos)
.HasForeignKey(foo => foo.ParentCustomerId);
modelBuilder.Entity<Foo>()
.HasKey(foo => foo.FooId);
要将数据播种到这种自引用关系中,我需要在 Configuration.cs 中包含以下内容:
// Default Foos - create
var foos = new[]{
new Foo { Name = "foo1", SubFoos = new List<Foo>() },
new Foo { Name = "foo2", SubFoos = new List<Foo>() },
new Foo { Name = "foo3", SubFoos = new List<Foo>() },
context.Tabs.AddOrUpdate(t => t.View, foos[0], foos[1], foos[2]);
context.SaveChanges();
// Add a SubFoo to a Foo
var parentFooId = foos[0].FooId;
var parentFoo = context.Foos.Include(f => f.SubFoos).SingleOrDefault(f => f.FooId == parentFooId);
// If no current SubFoos initiate an empty list
if (parentFoo.SubFoos == null)
parentFoo.SubFoos = new List<Foo>();
// Get another Foo to add as a SubFoo
var childFooId = foos[1].FooId;
// Check if child foo already exists and add if not
var childFoo = parentFoo.SubFoos.SingleOrDefault(f => f.FooId == childFooId);
if (childFoo == null)
parentFoo.SubFoos.Add(context.Foos.Single(f => f.FooId == childFooId));
context.SaveChanges();
关于c# - 导航属性 Project.Models.Customer.SubCustomers 的声明类型与指定导航的结果不兼容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26934962/
FogBugz 有没有办法创建一个过滤器,它是: [All] [open] [cases] assigned to [Developer A] with the exception of 1 or m
我是 java hibernate 的新手,我无法理解 Projections.property 和 Projections.groupProperty 之间的区别,两者都给出相同的结果。请解释其中的
让我们再试一次。我发布这个是为了回答 2 个问题 MS Project 2007 是否需要 SharePoint(我希望没有)? 做 你喜欢 MS Project 开发团队 - 它是有用的还是 疼痛?
我们的项目结构如下: sharedlib (lib-project, containing classes, that are useful in many apps) -> main-project
我正在尝试获取有关如何将 MS Project 2010 连接到 MS Project Server 2010 的教程或分步说明。 我已经在我的服务器上安装了 Server 2008 R2(64 位)
Projections.distinct(Projections.count("objectId")) 和 Projections.countDistinct("objectId") 谁能告诉我它们之
可以在项目 “project-a” 中创建一个主题“my-topic-project-a”,这样它就可以公开可见(已完成通过将角色“pub/sub subscriber” 设置为“allUsers”)
我创建了一个简单的 Kafka 消费者,它返回 Flux对象(收到的消息),我正在尝试使用 StepVerifier 对其进行测试. 在我的测试中,我做了这样的事情: Flux flux = cons
我有一个项目,最初是在 Eclipse 中,然后我设法将它转换为 gradle,并且在 Android Studio 中一切正常。 但后来我没有在这个项目上工作一段时间,几个月后当我回到项目时,我很惊
我正在研究 CQRS/ES 架构。我们将多个异步投影并行运行到读取存储中,因为某些投影可能比其他投影慢得多,并且我们希望与写入端保持更多同步以实现更快的投影。 我试图了解有关如何生成读取模型以及这可能
第一次尝试使用 Java 持久性注释创建多对多关系。 场景:Java 类Project 包含子项目,它只是Projects 的List。没有反向(没有 super 项目)成员。所以我认为多对多关系对于
我有现有的 C 代码和现有的 Makefile,我想将其包装到 Eclipse C 项目中(使用 Eclipse 3.4 Ganymede)。代码组织如下: 主目录:/Project/Software
我有一个 Eclipse 项目,不久前我设法在 Android Studio 中工作。它使用 TouchDB 库/项目,我现在想升级到他们最新的产品 couchbase-lite-android,看起
我将项目定义为包含主干、分支、标签子目录的 SVN 目录。 在确定何时将项目拆分为两个或将多个项目合并为一个时,您使用什么标准? - 每个“项目”一个应用程序,具有用于公共(public)源和资源的共
尝试在 Visual Studio 2008 中构建解决方案时遇到此错误。这是什么意思? 最佳答案 这可能意味着文件 bin\project.dll被另一个进程(可能是另一个 Visual Studi
此宏将隐藏/关闭 VBE 主窗口: Sub VBEMainWindowHide() 'close VBE window: Application.VBE.Window.Visible
我正在寻求开发户外应用程序,但不确定 tango 平板电脑是否可以在户外使用。那里的其他深度设备往往在室外效果不佳,因为它们依赖于从设备转换的红外光,然后在它从场景中的物体反射回来后进行观察。我一直在
在标准 .csproj您可以进入属性并设置默认命名空间。如何在 .xproj 中实现这一点项目使用 project.json ? 最佳答案 使用 ASP.NET Core 1.0.1,您可以在 pro
当 Redmine 上注册的项目超过 5 个时,主页“最新项目”框中列出的项目按创建日期降序排序(最近创建的优先),将旧项目(可能更新频率更高)排除在列表之外. 有没有办法按事件从最高到最低列出前 5
我开始学习android开发,但我不知道如何将库添加到项目中。我使用安卓工作室。我创建了新项目,但项目结构中没有项目设置。 最佳答案 在“项目”窗口中右键单击您的包名称,然后选择“打开模块设置”。这应
我是一名优秀的程序员,十分优秀!