什么时候我应该使用键,主键,唯一键和索引?
当前回答
唯一密钥:
可以有多个值为空。 任何两个元组在唯一键中都不能有相同的值。 一个或多个唯一键可以组合成一个主键,反之则不行。
主键
可以包含多个唯一键。 唯一表示一个元组。
其他回答
主键用于处理不同的表。这是关系数据库的基础。如果你有一个图书数据库,最好创建2个表- 1)图书和2)作者,INT主键“id”。然后在books中使用id而不是作者的名字。
如果不希望有重复的条目,则使用唯一键。例如,您可能在图书表中有标题,并希望确保每个标题只有一个条目。
唯一键:没有两行相似的列
Primary Key: Collection of minimum number of columns which can uniquely identify every row in a table (i.e. no two rows are similar in all the columns constituting primary key). There can be more than one primary key in a table. If there exists a unique-key then it is primary key (not "the" primary key) in the table. If there does not exist a unique key then more than one column values will be required to identify a row like (first_name, last_name, father_name, mother_name) can in some tables constitute primary key.
索引:用于优化查询。如果你要搜索或排序的基础上的一些列的结果很多次(例如。大多数人会通过名字而不是他们的卷号来搜索学生),那么如果列的值都被“索引”了,比如用二叉树算法,就可以优化。
唯一密钥:
可以有多个值为空。 任何两个元组在唯一键中都不能有相同的值。 一个或多个唯一键可以组合成一个主键,反之则不行。
主键
可以包含多个唯一键。 唯一表示一个元组。
KEY和INDEX是同义词。
当性能测量和EXPLAIN显示查询由于缺少索引而效率低下时,您应该添加索引。添加索引可以提高查询的性能(但会降低对表的修改速度)。
当您希望将该列(或多个列)中的值限制为惟一时,应该使用UNIQUE,以便尝试插入重复的值会导致错误。
PRIMARY KEY不仅是唯一的约束,而且它还暗示该列为NOT NULL。它用于为每一行提供一个标识。这对于通过外键约束连接另一个表非常有用。虽然一个表不需要有PRIMARY KEY,但这通常是一个好主意。
主键不允许空值,但唯一键允许空值。
在一个表中只能声明一个主键,但是一个表可以有多个唯一键(列赋值)。
推荐文章
- MySQL OR与IN性能
- 哪个更快/最好?SELECT *或SELECT columnn1, colum2, column3等
- 将值从同一表中的一列复制到另一列
- 删除id与其他表不匹配的sql行
- MySQL CPU使用率高
- INT和VARCHAR主键之间有真正的性能差异吗?
- 拒绝访问;您需要(至少一个)SUPER特权来执行此操作
- 从存储引擎得到错误28
- "where 1=1"语句
- 可能做MySQL外键的两个可能的表之一?
- 如果字段在MySQL中为空,则返回0
- 在MySQL中检测值是否为number
- MySQL中两个日期之间的差异
- 为什么在MySQL中文本列不能有一个默认值?
- 使用SQL查询查找最近的纬度/经度