外键(foreign key):
外面的键 (键不在自己表中), 如果一张表中有一个字段(非主键) 指向另外一张表的主键, 那么将该字段称之为外键.
外键可以在创建表的时候或者创建表之后增加(但是要考虑数据的问题). 一张表可以有多个外键.
创建表的时候增加外键: 在所有的表字段之后, 使用 foreign key(外键字段) reference 外部表(主键字段)
在新增表之后增加外键: 修改表结构
Alter table 表名 add[constraint 外键名字] foreign key(外键字段)reference 父表(主键字段);
修改外键与删除外键
外键不可以修改, 只能先删除后新增
删除外键语法
Alter table 表名 drop foreign key 外键名; --- 一张表中可以有多个外键, 但是名字不能相同.
外键作用
外键默认的作用有两点: 一个对父表, 一个对字表(外键字段所在的表)
对子表的约束: 子表数据进行写操作的时候, 如果对应的外键字段在父表找不到对应的匹配, 那么操作会失败(约束子表数据操作).
对父表的约束: 父表数据进行写操作(删和改: 都必须涉及到主键本身), 如果对应的主键在子表中已经被数据所引用, 那么就不允许操作.
外键条件:
1, 外键要存在: 首先必须保证表的存储引擎是 innodb(默认的存储引擎), 如果不是 innodb 存储引擎, 那么外键可以创建成功, 但是没有约束效果.
2, 外键字段的字段类型 (列类型) 必须与父表的主键类型完全一致.
3, 一张表中的外键名字不能重复.
4, 增加外键的字段(数据已经存在), 必须保证数据与父表主键要求对应.
外键约束: 就是指外键的作用.
删除后置空:
删除置空的前提条件: 外键字段允许为空(如果不满足条件, 外键无法创建)
联合查询:
将多次查询(多条 select 语句), 在记录上进行拼接(字段不会增加).
基本语法:
多条 select 语句构成, 每一条 select 语句获取的字段数必须严格一致(但是字段类型无关)
select 语句 1 Union[union 选项] select 语句 2......
Union 选项: 与 select 选项一样有两个
All: 保留所有(不管重复)
Distinct: 去重(整个重复), 默认的.
联合查询只要求字段一样, 跟数据类型无关
意义:
联合查询的意义分为两种:
1, 查询同一张表, 但是需求不同: 如查询学生信息, 男生身高升序, 女生身高降序.
2, 多表查询: 多张表的结构是完全一样的, 保存的数据 (结构) 也是一样的.
Order by 使用:
在联合查询中: order by 不能直接使用, 需要对查询语句使用括号才行.
之上的查询方式也是不成功的, 如果需要 order by 生效, 必须搭配 limit,limit 使用限定的最大数即可.
子查询(sub query):
查询实在某个查询结果之上进行的.(一个 select 语句内部包含另外一条 select 语句).
子查询分类:
子查询有两种分类方式: 按位置分类, 按结果分类.
按位置分类: 子查询 (select 语句) 在外部查询 (select 语句) 中出现的位置.
From 子查询: 子查询跟在 from 之后.
Where 子查询: 子查询出现在 where 条件中.
Exists 子查询: 子查询出现在 exists 中.
按结果分类: 根据子查询得到的数据进行分类(理论上讲任何一个查询得到的结果都可以理解为二维表)
标量子查询: 子查询得到的结果是一行一列.
列子查询: 子查询得到的结果是一列一行.
行子查询: 子查询得到的结果是多列一行(多行多列).
上面几个出现的位置是在 where 之后.
表子查询: 子查询得到的结果是多行多列(出现的位置是在 from 之后)
列子查询返回的结果比较: 一列多行, 需要使用 in 作为条件匹配, 其中在 MySQL 中还有几个类似的条件: all,some,any
=any -- in; 其中一个即可
any -- some; any 跟 some 是一样
=all -- 为全部
肯定结果:
否定结果:
行子查询:
返回的结果可以是多行多列(一行多列)
行子查询需要构造行元素, 行元素由多个字段构成.
表子查询:
子查询返回的结果是多行多列的二维表: 子查询返回的结果是当做二维表来使用.
表子查询: from 子查询, 得到的结果作为 form 的数据源.
Exists 子查询:
Exists: 是否存在的意思, Exists 子查询就是用来判断某些条件是否满足(跨表),Exists 是接在 where 之后, Exists 返回的结果只有 0 和 1;
来源: http://www.bubuko.com/infodetail-3089007.html