Rumah  >  Artikel  >  pangkalan data  >  sql主键和外键有什么区别

sql主键和外键有什么区别

清浅
清浅asal
2019-05-09 11:47:4115736semak imbas

sql主键和外键的区别:1、主键是唯一标识一条记录,不能有重复,不允许为空,而外键可以重复,可以是空值;2、主键是用来保持数据完整性,外键是用来建立与其他表联系用的;3、主键只有一个,外键可以有多个。

sql主键和外键有什么区别

sql主键和外键的区别:主键只有一个,不能重复也不允许有空值而外键可以有多个,可以重复也可以有空值;主键是用来保持数据完整性的,外键是用来与其他表建立联系的

sql主键和外键有什么区别

什么是主键、外键

关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录,该属性组就可以成为一个主键 
比如  

学生表(学号,姓名,性别,班级) 

其中每个学生的学号是唯一的,学号就是一个主键 

课程表(课程编号,课程名,学分) 

其中课程编号是唯一的,课程编号就是一个主键 

成绩表(学号,课程号,成绩) 

成绩表中单一一个属性无法唯一标识一条记录,学号和课程号的组合才可以唯一标识一条记录,所以学号和课程号的属性组是一个主键 
成绩表中的学号不是成绩表的主键,但它和学生表中的学号相对应,并且学生表中的学号是学生表的主键,则称成绩表中的学号是学生表的外键 

同理成绩表中的课程号是课程表的外键 

定义主键和外键主要是为了维护关系数据库的完整性,总结一下:

1.主键是能确定一条记录的唯一标识,比如,一条记录包括身份正号,姓名,年龄。

身份证号是唯一能确定你这个人的,其他都可能有重复,所以,身份证号是主键。 

2.外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。

比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。

主键和外键的区别

(1)主键是唯一标识一条记录,不能有重复,不允许为空;而外键可以重复,可以是空值

(2)主键是用来保持数据完整性,外键是用来建立与其他表联系用的

(3)主键只有一个,外键可以有多个

Atas ialah kandungan terperinci sql主键和外键有什么区别. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:sql语言包含哪些部分Artikel seterusnya:mysql如何防止sql注入