多表操作
外键
什么是外键
外键是指引用另一个表中的一列或多列,被引用的列应该具有主键约束或唯一性约束。
外键用于建立和加强两个表数据之间的链接。
为表添加外键约束
想要真正连接两个表的数据,就需要为表添加外键约束。
alter table 表名 add constraint FK_ID foreign key(外键字段名) references外表表名(主键字段名);
(1)建立外键的表必须是InnoDB型不能是临时表。因为MySQL中只有InnoDB型的表才支持外键。
(2)定义外键名时,不能加引号。如:constraint 'FK_ID' 或 constraint " FK_ID "都是错误的。
建立外键是为了保证数据的完整和统一性,即主表和从表中对应的数据保持统一,可以在建立外键时添加ON DELETE或ON UPDATE子句。
alter table 表名 add constraint FK_ID foreign key(外键字段名) REFERENCES 外表表名(主键字段名);
[ON DELETE {CASCADE | SET NULL | NO ACTION | RESTRICT}]
[ON UPDATE {CASCADE | SET NULL | NO ACTION | RESTRICT}]
CASCADE:删除包含于已删除键值有参照关系的所有记录
SET NULL:修改包含与已删除键值有参照关系的所有记录,使用NULL值替换
NO ACTION:不进行任何操作
RESTRICT:拒绝主键删除或修改外键关联列。
删除外键约束
解除两个表之间的关联关系时,就需要删除外键约束
alter table 表名 drop foreign key 外键名;
多表建立原则
一对多:
在多的一方创建一个字段作为外键指向一的一方的主键.
多对多:
创建一个中间表,中间表中至少两个字段,分别作为外键指向多对多双方各自的主键
一对一:
唯一外键对应,主键对应
操作关系表
关联关系
一对多(部门与员工) 、多对多(老师与学生)、 一对一(身份证)
添加数据
删除数据
连接查询
交叉连接
交叉连接返回的结果是被连接的两个表中所有数据行的笛卡尔积即行数的乘积。
SELECT * from 表1 CROSS JOIN 表2;
在实际开发中这种业务需求是很少见,一般不会使用交叉连接,而是使用具体的条件对数据进行有目的的查询。
内连接
内连接(INNER JOIN)又称简单连接或自然连接,内连接使用比较运算符对两个表中的数据进行比较,列出与连接条件匹配的数据行,组合成新的记录。
是将多个表连成一个表的查询。只有那些满足查询条件的列才会出现在最后的表中
SELECT 查询字段 FROM 表1 [INNER] JOIN 表2 ON 表1.关系字段 = 表2.关系字段
隐氏内连接
select * from A,B where 条件
显示内连接
select * from A inner join B on 条件
外连接
左连接的结果包括LEFT JOIN子句中指定的左表的所有记录,和所有满足连接条件的记录。如果左表的某条记录在右表中不存在,则在右表中显示为空。
右连接与左连接正好相反,返回右表中所有指定的记录和所有满足连接条件的记录。如果右表的某条记录在左表中没有匹配,则左表将返回空值。
SELECT 所查字段 FROM 表1 LEFT|RIGHT [OUTER] JOIN 表2
ON 表1.关系字段 = 表2.关系字段 WHERE 条件
左外连接
select * from A left outer join B on 条件
右外连接
select * from A right outer join B on 条件
自连接
就是一个表与其自己进行连接
复合条件连接查询(嵌套查询)
嵌套查询可以包括带有IN谓词的子查询、带有比较运算符的子查询、带有ANY或ALL谓词的子查询和带有EXISTS谓词的子查询。
在连接查询的过程中,通过添加过滤条件来限制查询结果,使查询结果更加精确。
子查询
带IN关键字的子查询
带EXISTS关键字的子查询
带ANY关键字的子查询
带ALL关键字的子查询
带比较运算符的子查询
sql执行顺序
1.from 表名
2.where 条件
3.group by
4.having
5.select
6.order by