主键外键与索引
来源:互联网 发布:2017dnf商人起步必知 编辑:程序博客网 时间:2024/06/08 12:09
一、什么是主键、外键:
关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录,该属性组就可以成为一个主键比如
学生表(学号,姓名,性别,班级)
其中每个学生的学号是唯一的,学号就是一个主键
课程表(课程编号,课程名,学分)
其中课程编号是唯一的,课程编号就是一个主键
成绩表(学号,课程号,成绩)
成绩表中单一一个属性无法唯一标识一条记录,学号和课程号的组合才可以唯一标识一条记录,所以 学号和课程号的属性组是一个主键
成绩表中的学号不是成绩表的主键,但它和学生表中的学号相对应,并且学生表中的学号是学生表的主键,则称成绩表中的学号是学生表的外键
同理 成绩表中的课程号是课程表的外键
定义主键和外键主要是为了维护关系数据库的完整性,总结一下:
主键是能确定一条记录的唯一标识,比如,一条记录包括身份正号,姓名,年龄。身份证号是唯一能确定你这个人的,其他都可能有重复,所以,身份证号是主键。
外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。二、 主键、外键和索引的区别 收藏
主键、外键和索引的区别?
主键
外键
索引
定义:
唯一标识一条记录,不能有重复的,不允许为空
表的外键是另一表的主键, 外键可以有重复的, 可以是空值
该字段没有重复值,但可以有一个空值
作用:
用来保证数据完整性
用来和其他表建立联系用的
是提高查询排序的速度
个数:
主键只能有一个
一个表可以有多个外键
一个表可以有多个惟一索引
聚集索引和非聚集索引的区别?
聚集索引一定是唯一索引。但唯一索引不一定是聚集索引。
聚集索引,在索引页里直接存放数据,而非聚集索引在索引页里存放的是索引,这些索引指向专门的数据页的数据。
阅读全文
0 0
- 主键外键与索引
- 主键与索引,主键与外键的关系
- Oracle 主键外键唯一索引索引
- .主键,外键和索引
- 主键、外键和索引
- 数据库 主键与索引键的区别
- 索引与主键(转载)
- 主键与聚集索引
- 主键与聚集索引
- 主键与索引
- 主键与唯一索引
- 主键与聚集索引
- 索引与主键
- 主键与主索引
- 主键与聚集索引
- 主键与主索引
- 主键与聚集索引
- 聚集索引与主键
- java中组合和继承的结合使用
- POJ 3580 SuperMemo(Splay树)
- CreateObject("Mercury.DeviceReplay")中的键盘值
- Android Studio中使用adb shell查看SharedPreferences文件
- 对 PInvoke 函数“...”的调用导致堆栈不对称。原因可能是托管的 PInvoke 签名与非托管的目标签名不匹配。请检查 PInvoke 签名的调用约定和参数与非托管的目标签名是否匹配
- 主键外键与索引
- [Java多线程 九]---JUC包下并发集合类
- vs2013 InstallShield打包卸载程序
- 机器学习第十课part3之Boost总结
- LeetCode Construct String from Binary Tree
- 【datatable】Cannot read property 'style' of undefined问题解决
- boost------signals2的使用
- powerdesign安装步骤
- 【PHP】调整数组顺序使奇数位于偶数前(闭包扩展)