关键字数据库
A. 数据库中什么是主关键字主关键字与外关键字的区别与联系
主关键字是用于唯一地标识表中的某一条记录。
联系:外键是相对于数据库设计中的参考完整性而言,与主键之间是彼此依赖的关系。
区别:
一、作用不同
1、主关键字:用来在一个表中引用来自于另一个表中的特定记录。是一种唯一关键字,表定义的一部分。
2、外关键字:公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外关键字。
二、组成不同
1、主关键字:主键可以由多个关键字共同组成,并且主关键字的列不能包含空值。主关键字是可选的,并且可在 CREATE TABLE 或 ALTER TABLE 语句中定义。
2、外关键字:可以为空值(除了SQLServer等一些数据库),但如果有值的话一定是参照的那个主表中的主键值。从表需要用到主表的属性,没有主表就没有从表。
三、特点不同
1、主关键字:可以由一个字段,也可以由多个字段组成,分别称为单字段主键或多字段主键。可以唯一确定表中的一行数据,或者可以唯一确定一个实体。
2、外关键字:.当一张二维表(如表A )的主关键字被包含在另一张二维表(如表B)中时,A表中的主关键字便成为B 表的外关键字。
B. 数据库里的关键字和索引有什么区别
1、索引可以加快表的查询速度,通常我们将经常用来查询的一个或者几个字段设置为索引,但不宜过多,3个内最好;
2、索引是建立在一个表上的说法,而主索引是建立在多个表上的,比如从多个表组成了一个视图A,而这个视图又包含了多个表里的索引,那么视图A里再设置索引,就叫主索引。
3、主键(关键字)是一个表里能够唯一区分开每条数据的字段,主键主要作用是用来和其他表进行关联的;虽然一个表可能存在多个能够区分开每条数据的字段,但我们通常选择最为有意思,易于关联其他表的那个字段作为主键。
4、主关键字如同2里的说法:主关键字是建立在一个表上的说法,而主关键字是建立在多个表上的,比如从多个表组成了一个视图A,而这个视图又包含了多个表里的关键字,那么视图A里再设置索引,就叫主关键字。
C. 数据库中什么是关键字/码/键
详情如下:
主码=主键=主关键字,关键字=候选码 候选关键字=候选码中除去主码的其他候选码。
码:唯一标识实体的属性或属性组合称为码。
候选码(关键字):某一属性组的值能唯一标识一个元组而其子集不能(去掉任意一个属性都不能标识该元组),则称该属性组为候选码(补充元组:表中的一行即为一个元组)。
主属性:候选码包含的属性(一个或多个属性)。
主码(主键、主关键字):若一个关系有多个候选码,选择其中一个为主码。
D. 数据库中,什么是超关键字,候选关键字,主关键字麻烦举例说明
1、主关键字:主关键字(primary key)是表中的一个或多个字段,它的值用于唯一的标识表中的某一条记录。主关键字又可以称为主键。 主键可以由一个字段,也可以由多个字段组成,分别称为单字段主键或多字段主键。并且它可以唯一确定表中的一行数据,或者可以唯一确定一个实体。
2、超关键字:二维表中,能够惟一确定记录的一个字段或几个字段的组合被称为“超关键字”。“超关键字”虽然能唯一确定记录,但是它所包含的字段可能是有多余的。
3、候选关键字:如果一个超关键字去掉其中任何一个字段后不再能唯一地确定记录,则称它为“候选关键字”(Candidate Key)。
(4)关键字数据库扩展阅读:
建立主关键字(主键)应该遵循的原则 :
1、主键应当是对用户没有意义的。如果用户看到了一个表示多对多关系的连接表中的数据,并抱怨它没有什么用处,那就证明它的主键设计地很好。
2、永远也不要更新主键。实际上,因为主键除了唯一地标识一行之外,再没有其他的用途了,所以也就没有理由去对它更新。如果主键需要更新,则说明主键应对用户无意义的原则被违反了。 注:这项原则对于那些经常需要在数据转换或多数据库合并时进行数据整理的数据并不适用。
3、主键不应包含动态变化的数据,如时间戳、创建时间列、修改时间列等。
4、主键应当由计算机自动生成。如果由人来对主键的创建进行干预,就会使它带有除了唯一标识一行以外的意义。一旦越过这个界限,就可能产生人为修改主键的动机,这样,这种系统用来链接记录行、管理记录行的关键手段就会落入不了解数据库设计的人的手中。