连接查询:多张表连接到一起,不管记录数如何,字段数一定会增加
分类:内连接,外连接,自然连接和交叉连接
交叉连接:cross join(笛卡尔积)
内连接:inner join,左右两张表中有连接条件匹配(不匹配的忽略)
外连接:outer(left/right) join,主表的记录一定会存在,匹配了就保留副表字段数据,没匹配到副表字段置空
自然连接:natural join,自动匹配(相同的字段名),using关键字
PHP操作mysql:
PHP充当客户端:开启mysql扩展
连接认证:mysql_connect
发送SQL获取结果:mysql_query
解析结果集:mysql_fetch系统
释放资源:mysql_free_result和mysql_close
错误处理:mysql_errno和mysql_error
外键
外键:foreign key,外面的键(键不在自己表中):如果一张表中有一个字段(非主键)指向另外一个表的主键那么该字段称之为外键
增加外键
外键可以在创建表的时候或者创建表之后增加(但是要考虑数据的问题)
一张表可以有多个外键
创建表的时候增加外键:在所有的表字段之后,使用foreign key(外键字段) references 外部表(主键字段)
在新增表之后增加外键:修改表结构
alter table 表名 add [constraint 外键名字] foreign key(外键字段) references 父表(主键字段);
修改外键&&删除外键
外键不可修改,只能先删除后新增
删除外键语法
alter table 表名 drop foreign key 外键名; -- 一张表中可以有多个外键,但是名字不能相同
外键作用
外键默认的作用有两点:一个对父表,一个对子表(外键字段所在的表)
对子表约束:子表数据进行写操作(新增和更新)的时候,如果对应的外键字段在父表中找不到对应的匹配,那么会操作失败(约束子表数据操作)
对父表约束:父表数据进行写操作(删除和修改:都必须涉及到主键本身),如果对应的主键在子表中已经被数据引用,那么就不允许操作
外键条件
外键要存在:首先必须保证表的存储引擎是innodb(默认的存储引擎):如果不是innodb存储引擎,那么外键可以创建成功,但是没有约束效果
外键字段的字段类型(列类型)必须与父表的主键类型完全一致
一张表中的外键名字不能重复
增加外键的字段(数据已存在),必须保证数据与父表主键要求对应
外键约束
所谓外键约束:就是外键的作用
之前所讲的外键作用:是默认的作用;其实可以通过对外键的需求,进行定制操作
外键约束有三种约束模式:都是针对父表的约束
district:严格模式(默认的),父表不能删除或者更新一个已经被子表数据引用的记录
cascade:级联模式:父表的操作,对应子表关联的数据也跟着被更新
set null:置空模式:父表的操作之后,子表对应的数据(外键字段)被置空
通常的一个合理做法(约束模式):删除的时候子表置空,更新的时候子表级联操作
指定模式的语法
foreign key(外键字段) references 父表(主键字段) on delete set null on update cascade
更新操作:级联更新