- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用 EF 6 和 Code First 开发与保险行业相关的应用程序。对于这个应用程序,每个帐户可以有多个策略,每个策略可以有多个交易。此外,每个帐户必须与身份(姓名、地址、城市等)有关系。 Policy 也与 Identity 有关系,但它是可选的。
由于帐户 -> 身份和帐户 -> 策略 -> 身份,我发现我需要使用 Fluent API 将至少其中一个路径的 WillCascadeDelete 设置为 False。
我的问题是如何将 Account.IdentityId 和 Policy.InsuredIdentityId 属性配置为外键?我已经避免向标识类添加任何导航/外键字段,因为永远没有理由从一个标识导航到另一个类。这就是我很难弄明白的原因吗?
public class Account
{
public long Id { get; set; }
public long IdentityId { get; set; }
public virtual Identity Identity { get; set; }
public ICollection<Policy> Policies { get; set; }
}
public class Policy
{
public long Id { get; set; }
public long AccountId { get; set; }
public virtual Account Account { get; set; }
public bool UseAccountIdentity { get; set; }
public long InsuredIdentityId { get; set; }
public virtual Identity InsuredIdentity { get; set; }
}
public class Identity
{
public long Id { get; set; }
public string Name { get; set; }
public string Address1 { get; set; }
public string Address2 { get; set; }
public string City { get; set; }
public string State { get; set; }
public string Zip { get; set; }
}
public class AccountConfiguration : EntityTypeConfiguration<Account>
{
public AccountConfiguration()
{
HasRequired(a => a.Identity).WithOptional(x => x.Account).WillCascadeOnDelete(false);
HasMany(a => a.Policies).WithRequired(p => p.Account).HasForeignKey(p => p.AccountId);
}
}
public class PolicyConfiguration : EntityTypeConfiguration<Policy>
{
public PolicyConfiguration()
{
HasOptional(p => p.InsuredIdentity).WithOptionalPrincipal().WillCascadeOnDelete(false);
}
}
作为附带问题,EF Code First 是否有任何好的书籍或其他引用资源?我有 Julia Lerman 的 Programming Entity Framework: Code First,对于它确实涵盖的示例来说很好,但它没有涵盖足够的案例。
最佳答案
首先,public ICollection<Policy> Policies { get; set; }
应该是 public virtual ICollection<Policy> Policies { get; set; }
.
只有当关系的一侧是一而另一侧是多时,您才能映射 EF 外键属性。任何时候你有 1:1 或 1:0..1 关系,从属实体将采用与委托(delegate)人相同的主键。在这些情况下,不能有外键,因为依赖项的外键是其主键。
所以对于这个:
HasRequired(a => a.Identity).WithOptional(x => x.Account)
...帐户的 ID 将与身份的 ID 具有相同的值。意思是,您可以完全删除 IdentityId
来自 Account
的属性(property)实体。但是我不明白该代码是如何编译的,因为 Identity
没有 Account
导航属性..?
当谈到您的政策映射时,这真的是您想要的方式吗?你说政策可以与身份有可选关系,但你这样做的方式是:
HasOptional(p => p.InsuredIdentity).WithOptionalPrincipal()
...意味着 Identity
只能相关(直接)做一个Policy
.使映射看起来像这样有什么问题?
HasOptional(p => p.InsuredIdentity).WithMany()
.HasForeignKey(x => x.InsuredIdentityId)
.WillCascadeOnDelete(false);
有了上面的内容,您仍然没有来自 Identity
的任何导航属性至 Policy
.你不需要一个,你可以调用 .WithMany()
作为无参数。然而,这告诉数据库设置 Identity
作为校长,Policy
作为依赖,所以你在数据库中有正常的 fk 关系,但你仍然无法导航到 Policy
来自 Identity
在代码中。
其他评论:
The Policy also has a relationship to an Identity, but it is optional.
这意味着Policy.InsuredIdentityId
应该是 System.Nullable<long>
.
关于c# - EF6 代码优先 : Using Fluent API to declare a Foreign Key,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21152966/
我有一个模板类 展览.h: template class ExpOf{ ... } 我在整个代码中反复使用,例如T = double [和其他类ExpOf应该一无所知]。 所以我认为一次性编译它是个
如果你有一个名为“Rock”的类,你会做类似的事情:- int main() { Rock; } 为什么会出现“声明未声明任何内容”错误? 它不应该只是调用默认构造函数并在那一刻创建对象吗?
这是一个非常业余的问题,我确信这将是一个非常简单的答案,但我似乎无法弄清楚问题所在。我有一个带有相应 .cpp 文件的头文件,但出于某种原因,每当我尝试使用 g++ 进行编译时,我都会收到错误消息:
我正在使用 MinGW 将我的 Linux 项目转换为在 Windows 上编译。它在 Linux 上编译和运行都很好,但是当我尝试用 MinGW 编译它时,它会出现以下错误消息: camera.h:
我收到“decleration does not declare anything [-fpermissive] 错误”;这是我的代码; #ifndef CAMERA_H #define CAMERA
我正在编写一些 cython 代码,但遇到了一个奇怪的问题。当我尝试将对象作为结构直接从 python 传递到 C 时,cython 生成的代码很好,但 gcc 不喜欢代码输出并给我以下错误:erro
typedef struct BO2Offsets { struct Prestige { u32 offset = 0x000000; char da
我不明白 C++ 中的某些东西,gcc 不喜欢我如何进行。 我做到了: if (!fModeMdi) MyFirstClass* main = (MyFirstClas
在 switch-case 语句中,declaration-with-initialization 是无效的,但允许 declaration-and-then-assignment。如以下代码片段所示
我在我的界面文件中收到一条奇怪的警告。 这也出现在我为此声明属性的那一行。 谁能帮帮我? 最佳答案 在您的项目中的某处,您有一个 #define 将 xOffset 定义为空(除了注释)。像这样: #
declare +x 下面做了什么? (特定于 Bash。)我理解 declare -x,但不理解 declare +x: function the_func { declare +x MY_VA
由于我是 Symfony 的新手,我尝试使用 Doctrine 创建实体关系。我收到错误 “[bundle/entity/file_location”中的属性“report”已经声明,但在我尝试更新架
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 2年前关闭。 Imp
这是给我错误的代码: TAdvSmoothDockItems = class(TCollection) private FOwner: TAdvSmoothDock; FOnChange: T
我对 python 很陌生,我尝试制作一个简单的 GUI 程序。但是,我遇到了一个“问题”,确切地说是一个警告,上面写着:“m”未在全局范围内定义(Python(变量未定义全局))。 我知道如果你想在
当我用 GCC 编译程序时,它会显示“警告:声明未声明任何内容 [-fpermissive]”。 有问题的代码如下: typedef int BOOL; 如何清除警告? 最佳答案 您可以尝试以下操作。
我正在编写一个包含键值对集合的重要类,在编译期间我收到一个我无法弄清楚的非常奇怪的错误。在一个与这里的函数非常相似的函数中,但由于所需代码的复杂性而没有上下文,我收到错误: TValue& opera
这个问题很简单。为了进一步阐明,下面代码中的 Foo1 和 Foo2 在它们的声明方式方面到底有什么区别(例如,使用 class Foo1 { 。 .. }; 而另一个使用 typedef class
我正在开发 Web 项目,并且在从 Oracle 数据库迁移到 mysql 数据库时遇到一些问题。我想用这段代码创建函数: DROP FUNCTION IF EXISTS F_MANIFEST_GAB
是否有一个标志可以传递给 gcc 以禁用此警告?我知道它的作用,但这对我的程序来说无关紧要。 编辑:我只想禁用警告,保持代码不变。编译以下代码会生成警告: struct post{ unsigne
我是一名优秀的程序员,十分优秀!