感悟网 导航

什么是主码?什么是外码?为什么要设定外码?

作者&投稿:左丘琛 (若有异议请与网页底部的电邮联系)
为什么要设定主码?怎样的属性适合做主码~

1.如果不设定,任一属性都有可能从属性集中删掉,否则将破坏唯一性的性质。
2.可以将关系的所有属性的组合作为主码,通常用较小的属性组合作为主码。

1、主码:保证实体的完整性;加快数据库的操作速度;在表中添加新记录时,ACCESS会自动检查新记录的主键值,不允许该值与其他记录的主键值重复;ACCESS自动按主键值的顺序显示表中的记录。如果没有定义主键,则按输入记录的顺序显示表中的记录。
2、外码:主码和外部码提供了一种表示不同关系之间相互关联的手段。如关系模式供应商和供应之间的关系就是通过供应商名称来体现的。



建立主码应该遵循的原则
1、主键应当是对用户没有意义的。如果用户看到了一个表示多对多关系的连接表中的数据,并抱怨它没有什么用处,那就证明它的主键设计地很好。
2、永远也不要更新主键。实际上,因为主键除了唯一地标识一行之外,再没有其他的用途了,所以也就没有理由去对它更新。如果主键需要更新,则说明主键应对用户无意义的原则被违反了。
注:这项原则对于那些经常需要在数据转换或多数据库合并时进行数据整理的数据并不适用。
3、主键不应包含动态变化的数据,如时间戳、创建时间列、修改时间列等。
4、主键应当由计算机自动生成。如果由人来对主键的创建进行干预,就会使它带有除了唯一标识一行以外的意义。一旦越过这个界限,就可能产生人为修改主键的动机,这样,这种系统用来链接记录行、管理记录行的关键手段就会落入不了解数据库设计的人的手中。
以上内容参考:百度百科-主关键字、百度百科-外部码

⑴主码是表中的一列或多列的组合,它的值唯一标识了表中的一行记录。
⑵外码是这样的一列或多列的组合,它存在于表1中,但不是表1的主码;它同时存在于表2中,而且是表2的主码,于是称这一列或多列的组合是表1相对于表2的外码。

《什么是候选码、主码、全码、外码》
答:候选码、主码、全码和外码都是关系数据库中重要的概念,用于描述数据表的属性和关系。候选码是一个或多个属性的集合,可以用来唯一标识表中的每个元组(记录)。换句话说,候选码确保表中的每个记录都可以被唯一地区分。一个表可以有多个候选码。主码是从候选码中选出的一个用于唯一标识表中每个元组...

《什么是主码?如何判断?》
答:简称外码或外键。如:职工(职工号,姓名,性别,职称,部门号)部门(部门号,部门名,电话,负责人)其中职工关系中的“部门号”就是职工关系的一个外码。在此需要注意,在定义中说X不是R的码,并不是说X不是R的主属性,X不是码,但可以是码的组成属性,或者是任一候选码中的一个主属性。

《什么是候选码、主码、全码、外码》
答:候选码、主码、全码和外码是关系数据库中的概念,用于描述数据表中属性的不同作用和特点。候选码是指能够唯一标识一个元组(或记录)的属性或属性组。在关系数据库中,每个元组都应该有一个唯一的标识,以便能够准确地检索和修改它。候选码就是用来实现这一目标的。例如,在员工信息表中,员工的身份证...

《简述关系模式中主码与外码的关系。》
答:主码和外码是用来实现参照完整性的,外码的数据项需参照主码的数据项来操作。具体实现是在创建数据库时为表间创立关系。如:三个关系:学生信息表(学号、姓名、性别、出生年月、籍贯、所属学院) //学号 是主键(主码 课程表(课程号,课程名称,学分) //课程号 是主键(主码 成绩表(学...

《候选码、主码、全码、外码、主属性、主键、主关键字、非主属性清晰总结...》
答:在数据表的世界里,有几种关键的概念,如候选码、主码、全码、外码,它们在数据库设计中扮演着重要角色。下面,让我们一起深入理解这些概念,让它们在你的数据库知识库中清晰起来。 1. 理解基础 在开始之前,要明白"键"和"码"是同义词,即主键、主码和主关键字。它们都是用来唯一标识表中每一行数据的属性或属性组...

《数据库知识里的主码,候选码,外码如何更准确的理解它们之间的关系?》
答:在数据库的世界里,主键、候选键和外键这三个概念是数据结构的核心,它们之间存在着紧密的逻辑联系。首先,让我们深入了解什么是候选键:候选键(Candidate Key)是关系数据库中的独特标识符,它由一组属性组成,能够唯一确定一个数据记录。每个关系中可能存在多个候选键,但通常我们选择其中的一个,赋予它...

《数据库中外码的定义》
答:问题四:sql数据库中主码外码候选码等等一共有哪些码 都是什么意思 候选码是能够唯一标识一个记录的一组或一个属性,主码是从多个候选码中选择出的一组 外码是在本关系中的属性,但在另一个关系中作为主码的属性 问题五:数据库候选码和外码的确立 多对多 关系不能直接反应在数据库中,需要...

《SQL中外码有什么用?》
答:个人理解,仅供参考。主码是用于唯一标识一行数据的,类似unique,比如插入的时候会查重。可能也有别的作用,如索引啊之类的,我没学透也不敢胡说。至于外码,是标识这一个关系(表)中的某个属性或者属性集是其他关系(表)中的码,那么插入时就会去另一个表中查看有没有这个码。如果没有,则插入...

《SQL语言创建表时候怎么定义主码和外码》
答:SQL语言创建表时候用Primary Key(属性名)定义主码,用Foreign Key(属性名)定义外码。主码是一种唯一关键字,表定义的一部分。一个表的主码可以由多个关键字共同组成,并且主码的列不能包含空值。主码是可选的,并且可在 CREATE TABLE语句中用Primary Key(属性名)定义。将一个表的值放入第二个...

《关系模式中的主码和外码是否一个意思?》
答:所以,课本上的定义其实没有错,而且必须那么定义(一个关系模式的主码不能同时也是外码)。因为如果关系模式R的主码也是外码的话,外码是另一个关系的主码,这就说明存在一个关系它的主码和R的一模一样。这种情况2个关系是可以合并的。所以课本才要特别说明主码不能做外码。

   

返回顶部
本页内容来自于网友发表,若有相关事宜请照下面的电邮联系
感悟网