- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要一些最佳实践和性能建议。
假设我有三个表:Employees、Jobs 和 Ranks。每个员工都有一份工作和一个等级,所以显然我应该在我的 Employees 表中引用这些表。
我的问题是,以下哪个选项最好:
1) 每个职位和级别都存储有一个唯一的 ID 和一个描述性名称。 Employees 表应引用其他表中的唯一 ID,从而节省内存(描述性名称仅在 Jobs/Ranks 表中保存一次),但要查看描述性名称,我需要执行 JOIN
s:
SELECT Employees.EMPL_ID, Ranks.R_NAME, Jobs.J_NAME
FROM Jobs
JOIN Ranks ON Ranks.R_ID=Employees.RANK
JOIN Jobs ON Jobs.J_ID=Employees.JOB
2) 只是唯一的描述性名称。这可能会浪费内存,因为我重复保存了每个职级/职位的描述性名称,但我在 SELECT
语句上节省了时间
<编辑:>
澄清一下,我主要关心的是如果我需要使用多个 JOIN
而不是一个执行 SELECT
时我必须处理的性能SELECT
语句。
我希望能够处理大量流量 - 具体来说,员工请求查看他们的职位和等级。
<编辑>
例子:
选项 1(ID 和名称):
Employees:
__________________________
/ EMPL_ID | RANK | JOB \
| 1 | 2 | 3 |
| 1 | 1 | 3 |
| 1 | 1 | 1 |
\__________|________|______/
Ranks:
__________________
/ R_ID | R_NAME \
| 1 | GRUNT |
| 2 | BOSS |
\________|_________/
Jobs:
____________________
/ J_ID | J_NAME \
| 1 | JANITOR |
| 3 | PRESIDENT |
\________|___________/
选项 2(唯一名称):
Employees:
_______________________________
/ EMPL_ID | RANK | JOB \
| 1 | BOSS | PRESIDENT |
| 1 | GRUNT | PRESIDENT |
| 1 | GRUNT | JANITOR |
\__________|________|___________/
Ranks:
__________
/ R_NAME \
| GRUNT |
| BOSS |
\__________/
Jobs:
___________
/ J_NAME \
| JANITOR |
| PRESIDENT |
\___________/
最佳答案
最好的做法是始终为每张 table 准备这个。通常称为 'id' 或 the-table-name_id'
它应该没有商业值(value)。
许多“保证唯一”的记录后来发现需要或存在或重复的记录,并且始终拥有唯一的主键在满足/发现时有很大帮助。
“唯一”的一个例子……那不是……如果一个系统有人们的社会安全号码,它们应该是唯一的。但是,可能会打错。然后,当具有“错误输入”值的人出现并且他们的号码被绑定(bind)输入时......在允许/解决这个问题时,这将非常有助于所有行拥有自己的 id,该 id 不是 ssn 并且没有商业值(value)除了标识行之外的所有内容。
唯一记录是一个众所周知的问题。为所有记录设置唯一 ID 是解决该问题的解决方案的一部分。
上述所有情况的异常(exception)是性能。我不太关心几千条记录的连接速度,因为 SQL 数据库经过精心设计以提高速度。我发现唯一标识的优势胜过劣势。可能会出现你因为性能需求而改变上述做法的情况。例如,如果有数百万条记录必须加载到内存中,唯一 ID 空间的开销可能会成为一个问题。通常,如果出现这些情况,人们就会开始关注无 SQL 解决方案,例如 Redis、MongoDB 等。
这里有一些关于 SO 和其他网站的额外引用:
What's the best practice for primary keys in tables?
in general, should every table in a database have an identity field to use as a PK?
is an ID column really needed in SQL?
正如在一个答案中评论的那样“在社区中使用自然键与代理键进行某种宗教辩论”。还有一条评论是关于回答者如何获得他们的“规则”的……嘻嘻……
关于mysql - 我应该为唯一名称表中的每一行提供行 ID 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13669693/
出现在 python 2.7.8 中。 3.4.1 不会发生这种情况。 示例: >>> id(id) 140117478913736 >>> id(id) 140117478913736 >>> id
好吧,我对动态创建的控件的 ID 很困惑。 Public Class TestClass Inherits Panel Implements INamingContainer
我收到下面的错误,说有堆栈溢出。发生这种情况是因为带有 IN (id, id, id...id) 的 SQL 语句有大量参数。有没有什么办法解决这一问题?这是在我使用 Eclipse 的本地环境中发生
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
为什么 CPython(对其他 Python 实现一无所知)有以下行为? tuple1 = () tuple2 = ()
非常简单的问题:当我有一个持久对象时,它通常有一个名为 ID 的属性(对于抽象类)。 那么..命名约定是ID还是Id? 例如。 public int ID { get; set; } 或 public
知道为什么我会收到此错误,我已经尝试了所有命名约定(小写/大写) 我正在使用 Vaadin,这是我的代码片段: public class Usercontainer extends BeanI
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
我需要改变表的所有主键 UPDATE TODO SET id = id + 1 但我做不到(Demo 来自 Ahmad Al-Mutawa 的回答)描述了原因。主键不能这样改。 我也不能根据这是 sq
我正在尝试列出与用户相关的讨论列表。 想象一下,如果你愿意的话: posts -------------------------------------------------------------
我有一个表,其中包含一些具有自己的 ID 和共享 SKU key 的文章。我尝试使用左连接进行查询,并使用组结果获取从查询返回的所有 id。 我的数据结构是这样的: id - name -
在下表People中: id name 1 James 2 Yun 3 Ethan 如果我想找到最大 ID,我可以运行此查询 select max(id) id from People; 结果是
我正在产品页面上创建评论模块,其中显示垃圾评论选项,并显示 onclick 显示和隐藏弹出窗口。现在它在单个评论中工作正常但是当评论是两个时它同时打开两个因为类是相同的。现在这就是为什么我想要获取父
根据 REST 哲学,PUT操作应该(取自维基百科): PUT http://example.com/resources/142 Update the address member of the co
我想知道如何在使用 PHP 或 JavaScript 进行身份验证后从 Google Analytics 获取 Property Id、View Id 和 Account Id?因为我希望能够将它们存
我想使用所选按钮的 ID 进行删除。但我不知道如何从中获取/获取 id。我尝试了 this.id 但不起作用。 这是我创建按钮的地方: var deleteEmployer= document.cre
我有一个具有以下结构的表“表” ID LinkedWith 12 13 13 12 14 13 15 14 16
请不要在未阅读问题的情况下将问题标记为重复。我确实发布了一个类似的问题,但 STACKOVERFLOW 社区成员要求我单独重新发布修改后的问题,因为考虑到一个小而微妙的修改,解决方案要复杂得多。 假设
在 Android Studio 中,我创建了一个 Person.java 类。我使用Generate 创建了getter 和setter 以及构造函数。 这是我的 Person.java 类: pu
如何在 jQuery 中制作这样的东西: //这是显示的主体 ID //当我悬停 #hover-id 时,我希望 #principal-id 消失并更改 。但是当我将光标放在 #this-id 上时
我是一名优秀的程序员,十分优秀!