- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以基本上哪个在性能和空间方面更好:
idPerson Name Gender Age
1 John Male 19
2 Anna Female 22
或者这样:
idPerson Name Age idGender
1 John 19 1
2 Anna 22 2
idGender Gender
1 Male
2 Female
我认为第二个更好,因为每次重复男/女会占用更多空间,但我认为它可能会因关系而变慢。我错了?有更好的方法吗?
最佳答案
which is better in terms of performance and space
计算机科学中的大多数决策通常都是时间和空间之间的权衡。
在您的情况下,第一个解决方案(在表中存储最多 6 个字符的字符串)最终会使用更多空间,但会导致该字符串直接可用于表上的查询;而第二个解决方案(存储一个整数表示,其含义可以在第二个表中查找)将使用更少的空间,但需要更多的工作来发现字符串(尽管它确实可以通过定义 foreign key constraint 来限制可能的值) .
另一种方法可能是使用 MySQL 的 ENUM
类型,它使您能够处理字符串,同时有效地“在幕后”仅存储一个整数。您不妨考虑 Chris Komlenic 的文章 8 Reasons Why MySQL's ENUM Data Type Is Evil在决定采取这一行动之前。
关于mysql - 为性别使用新表或将其添加为人员表中的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18941742/
是否有用于手动测试的代码覆盖工具?比如我新写了30行代码,编译,然后运行,有什么办法可以快速验证这30行都运行了吗? 另外,后来,在我将代码 checkin 正式版本后,有什么方法可以验证测试部门在进
老实说,这是一个家庭作业问题,但我已经浪费了好几个小时,而且无法正确解决。它返回错误数量的结果或错误的数据: 我需要选择参与指导电影和/或在电影中表演的每个人以及他们所做的次数,如果至少 5 次。 有
我正在尝试测试 MacOS 的应用内购买。输入测试用户凭据后,App Store 提示:“当前收据无效或 ds 人员 ID 不匹配。”并且购买失败。 最佳答案 我尝试了很多方法来解决这个问题。 Get
我正在为 Jenkins 使用 ActiveDirectory 插件,因此用户必须使用他们的凭据登录到 Jenkins。然后用户在 Jenkins 中被称为 joe.doe,这很完美。 当同一个人 c
如何从 Infopath 人员/组选取器检索电子邮件地址?当我将人员/组选取器添加到 infopath 表单时,我只得到 3 个字段 DisplayName、AccountId、AccountType
在 Snow Leopard 中,可以在 iCal 事件中显示空闲/忙碌时间。我搜索了 CalStore.framework 的 header ,但找不到任何描述该字段的属性。如何检索日历事件的忙/闲
是否有人成功地从专门针对 SharePoint 2013 的新建或编辑表单中获取用户(个人或组)字段的值? 我已经尝试了通过搜索互联网找到的所有解决方案以及我自己能想到的所有解决方案,所有结果都为空白
所以我需要将一个 Twitter 帐户添加到 ABRecordRef 中。然而,最快的方法似乎是获取社交资料属性的多值引用,创建它的可变版本,查找它是否有 Twitter 条目,如果已经有,则创建
我正在尝试将使用 Tomcat(最初是 5.5,但可以与 7 一起使用)在 MyEclipse 中开发的应用程序部署到我们的演示服务器 (Sun Java Web Server 7)。不幸的是,所有设
我是一名优秀的程序员,十分优秀!