mysql_外键运用
2018-01-10 15:00
183 查看
外键
外键:foreign key,外面的键(键不在自己表中),如果一张表中有一个字段(非主键)指向另一张表的主键,那么将该字段称之为外键。
增加外键
外键可以在创建表的时候 或者创建表之后增加(但是要考虑数据的问题),一张表可以有多个外键。
外键:要求字段本身必须先是一个索引(普通索引),如果字段本身没有索引,外键会先创建一个索引,然后才会创建外键本身。
创建表的时候增加外键:在所有的表字段之后,使用foreign key(外键字段) references 外部表(主键字段)
在新增表之后增加外键
alter table 表名 add [constraint 外键名字]foreign key(外键字段) reference 父表(主键字段)
修改外键&删除外键
外键不可修改:只能先删除后新增
删除外键语法:
alter table 表名 drop foreign key 外键名
外键作用
外键默认的作用有两点:一个对父表,一个对子表(外键字段所在的表)
对子表的约束:子表数据进行写操作(增和改)的时候,如果对应的外键字段在父表找不到对应的匹配;那么会操作失败(约束子表数据操作)
对父表约束:父表数据进行写操作(删和改,都必须涉及到主键本身),如果对应的主键在子表中已经被数据所引用,那么就不允许操作
外键条件
1.外键要存在:首先必须保证表的储存引擎是innodb(默认的存储引擎),如果不是innodb存储引擎,那么外键可以创建成功,但是没有约束效果
2.外键字段的字段类型(列类型)必须与父表的主键类型完全一致
3.一张表中的外键名字不能重复
4.增加外键的字段(数据已经存在),在新增外键的时候无法改变不能匹配数据的事实。
外键约束
所谓外键约束:就是指外键的作用
之前所说的外键作用:是默认的作用;可以通过对外键的需求进行定制操作
外键约束的三种约束模式:
district:严格模式(默认的),父表不能删除或者更新一个已经被子表数据引用的记录
Cascade:级联模式:浮标的操作对弈ing子表关联的数据也跟着操作
set null:置空模式:父表的操作之后,子表对应的数据(外键字段)被置空
通常一个合理的约束模式:删除的时候子表置空,更新的时候子表级联操作
指定模式的语法:
foreign key(外键字段) references 父表(主键字段) on delete模式 on update 模式;
注意:删除置空的前提条件:外键字段允许为空
外键对于PHP来说,降低了PHP对数据的可控性,同常在实际开发中,很少使用外键来处理。
外键:foreign key,外面的键(键不在自己表中),如果一张表中有一个字段(非主键)指向另一张表的主键,那么将该字段称之为外键。
增加外键
外键可以在创建表的时候 或者创建表之后增加(但是要考虑数据的问题),一张表可以有多个外键。
外键:要求字段本身必须先是一个索引(普通索引),如果字段本身没有索引,外键会先创建一个索引,然后才会创建外键本身。
创建表的时候增加外键:在所有的表字段之后,使用foreign key(外键字段) references 外部表(主键字段)
在新增表之后增加外键
alter table 表名 add [constraint 外键名字]foreign key(外键字段) reference 父表(主键字段)
修改外键&删除外键
外键不可修改:只能先删除后新增
删除外键语法:
alter table 表名 drop foreign key 外键名
外键作用
外键默认的作用有两点:一个对父表,一个对子表(外键字段所在的表)
对子表的约束:子表数据进行写操作(增和改)的时候,如果对应的外键字段在父表找不到对应的匹配;那么会操作失败(约束子表数据操作)
对父表约束:父表数据进行写操作(删和改,都必须涉及到主键本身),如果对应的主键在子表中已经被数据所引用,那么就不允许操作
外键条件
1.外键要存在:首先必须保证表的储存引擎是innodb(默认的存储引擎),如果不是innodb存储引擎,那么外键可以创建成功,但是没有约束效果
2.外键字段的字段类型(列类型)必须与父表的主键类型完全一致
3.一张表中的外键名字不能重复
4.增加外键的字段(数据已经存在),在新增外键的时候无法改变不能匹配数据的事实。
外键约束
所谓外键约束:就是指外键的作用
之前所说的外键作用:是默认的作用;可以通过对外键的需求进行定制操作
外键约束的三种约束模式:
district:严格模式(默认的),父表不能删除或者更新一个已经被子表数据引用的记录
Cascade:级联模式:浮标的操作对弈ing子表关联的数据也跟着操作
set null:置空模式:父表的操作之后,子表对应的数据(外键字段)被置空
通常一个合理的约束模式:删除的时候子表置空,更新的时候子表级联操作
指定模式的语法:
foreign key(外键字段) references 父表(主键字段) on delete模式 on update 模式;
注意:删除置空的前提条件:外键字段允许为空
外键对于PHP来说,降低了PHP对数据的可控性,同常在实际开发中,很少使用外键来处理。
相关文章推荐
- Mysql主键、外键运用于关联查
- MySQL多表查询之外键
- mysql取消外键检查
- mysql 悲观锁 的运用
- mysql设置外键保存就消失,保存不成功
- mysql 创建外键
- [进阶]MySQL学习笔记四数据表外键ForeignKey
- mysql 禁用和启用外键
- MySQL 新建数据库、建立索引、建立外键
- django1.9.5 sqlite3迁移数据到mysql(外键迁移没有问题)
- MySQL如何添加外键
- mysql外键(FOREIGN KEY)的简单使用
- mysql 创建外键提示 Can't create table 'xx.#sql-d14_4f' (errno: 150)
- 在MySQL中利用外键实现级联删除
- 史上最简单的 MySQL 教程(二十八)「外键(上)」
- MySQL外键及级联删除 && 表的存储引擎与创建索引 && 删除数据库和表
- MySQL之外键约束
- MySQL 外键的设置及作用
- 关于Mysql 外键使用的问题 推荐
- mysql 外键约束(未完)