- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
用户总是有一个钱包。一个钱包始终属于一个用户。
因为我想分离与钱钱包相关的属性,所以我创建了 Wallet 对象并能够跟踪钱交易,......我创建了
public Wallet : Entity<int>
{
public double Amont {get; set;}
public IList<MoneyTrans> Transactions {get; set;}
}
由于这显然是一对一的关系,是否可以使用一对一的关系进行映射?
一对一是不好的策略吗?
最佳答案
我不得不附加答案,观点相反。不要不使用一对一
映射。至少对于 NHibernate。
我不是在谈论概念领域驱动设计。关于我在数据库设计和 NHibernate 使用方面的经验。
1) 一对一
- 刚性数据库设计
首先,当业务需求发生变化时,使用共享主键进行设计(继承除外)可能会在以后导致许多问题。
典型场景,与示例非常相似23.2. Author/Work ,其中 Author 被一对一
映射到 Person。因此,Author 的 id(主键)来自于一个 Person(id)。业务迟早会来问我们是否可以将人员映射到作者(参见 Lars Kepler 示例)
我在这里想说的是:Chapter 24. Best Practices (让我引用一点)
Declare identifier properties on persistent classes.
NHibernate makes identifier properties optional. There are all sorts of reasons why you should use them. We recommend that identifiers be 'synthetic' (generated, with no business meaning) and of a non-primitive type. For maximum flexibility, use Int64 or String.
如此处(以及我的经验)所述,让所有实体都拥有自己的代理主键是非常有益的。稍后关系的变化 - 只会影响引用(在代理键之上),而不影响表/实体本身。
2) 一对一
与NHibernate 不能偷懒
事实上这就是一个原因,为什么 (尽管我尝试了几次) 目前根本不使用 one-to-one
。 一对一不支持延迟加载。搜索更多信息,但可以在此处找到很好的解释:
In other words, one-to-one cannot be lazily loaded, which is one of the reasons why it is recommended to use two many-to-one instead.
如问题下方评论中的链接之一所述(引用)
You can either include all those attributes as columns into your entity table - but in that case, lots of columns would end up empty for a significant number of the entries.
Or: you can put those "optional" attributes into a separate table, set up a 1:1 (or rather: 0:1) relationship with the base entity table,
嗯,使用 NHiberante 不会有太大的改进。这个建议是错误的。 Lazy loading of one-to-one isn't supported...
总结:
这就是我强烈建议的原因:尽可能使用多对一
或一对多
。你会收获更多...
关于c# - 是一对一的关系糟糕的策略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23425600/
我想在这里说的是我在从之前离开的相同状态重新启动我的应用程序时遇到的问题。我在这方面做了很多研发,并且已经解决了 stackoverflow 中发布的问题。所以请不要说它是重复的。 我试过设置这些选项
当我在我的类中实现 __cmp__ 函数时,python 是否会在内部重载“==”,我们在 C++ 中是如何做到的? 只是好奇。我是 python 的新手。 :) 最佳答案 ==的含义当您定义 __c
我在 Raspberry Pi2 上安装了 Gitlab,几个月来它运行良好。但自从关闭了RPi的电源后,它就不再起作用了。网页返回502错误。 502 Whoops, GitLab is takin
有人知道用户登陆带有Webfonts的页面时为什么Google Chrome浏览器崩溃吗 它并不会一直发生,而是经常发生 我刚得到一个蓝屏页面,却不知道为什么:该页面不是来自重定向时就很好了。 这是我
当我登录时,Skype始终会给出此错误。 糟糕,Skype存在问题。尝试注销然后重新登录。 STARTUP_LOAD_ERROR MACBOOK 最佳答案 Macbook 用户 退出Skype 回家
我正在尝试从 flutter 开始,首先我在 cmd 上运行 flutter doctor 它有效。在我安装了 ANDROID SDK 之后,同样的命令 flutter doctor 给了我异常:
从 android studio 终端运行 flutter attach 不工作。显示错误flutter 意外退出。 终端输出: flutter attach Checking for adverti
当使用 TinyMCE 4 测试所有浏览器时,Chrome 非常慢。 (我尝试从 TinyMCE 中删除所有插件,但没有任何区别。) Chrome 需要大约 20-25 秒在 TinyMCE 中呈现一
我试图让下面的脚本工作,以便从远程服务器(服务器 1)读取特定目录中的 CSV 文件列表,并将数据移植到另一台服务器的 PostgreSQL 数据库中。 我已经创建了一个 rsa SSH key 并将
在嵌入式 linux 环境中(在 PowerPC 上定制的 2.4.25)几个小时后我得到以下内核 panic : Oops: kernel access of bad area, sig: 11 N
在将现有 Node.js (Hapi.js) + RethinkDB 从 OVH VPS(最小 vps)迁移到 AWS Lambda( Node )+ DynamoDB 的过程中,我最近遇到了一个非常
我是一名优秀的程序员,十分优秀!