mysql基础(35)_外键约束

外键约束

外键约束:通过建立外键关系之后,对主表和从表都会有一定的数据约束效率。

约束的基本概念:
1、当一个外键产生时:外键所在的表(从表)会受制于主表数据的存在从而导致数据不能进行某些不符合规范的操作(不能插入主表不存在的数据)
2、如果一张表被其他表外键引入,那么该表的数据操作就不能那么随意,必须保证从表数据的有效性(不能随便删除一个被从表引入的记录)

-- 上节内容已经知道了:外键列只能插入参照列(主表)存在的值,在上节内容基础上设置了字符集然后清空内容:
mysql> select * from foreign_key;
Empty set (0.00 sec)

mysql> insert into foreign_key values(null,'张三','1');
Query OK, 1 row affected (0.04 sec)

mysql> insert into foreign_key values(null,'李四','2');
Query OK, 1 row affected (0.13 sec)

mysql> select * from foreign_key;
+----+------+----------+
| id | name | class_id |
+----+------+----------+
|  1 | 张三 |        1 |
|  2 | 李四 |        2 |
+----+------+----------+
2 rows in set (0.00 sec)

mysql> select * from student;
+----+------+
| id | name |
+----+------+
|  1 | 小明 |
|  2 | 小可 |
|  3 | 小艾 |
|  4 | 小新 |
+----+------+
4 rows in set (0.00 sec)

-- 主表id=1字段信息被foreign_key表外键引入,因此不能随意删除,所以提示错误!
mysql> delete from student where id=1;
ERROR 1451 (23000): Cannot delete or update a parent row: a foreign key constraint fails (`test`.`foreign_key`, CONSTRAINT `foreign_key_ibfk_1` FOREIGN KEY (`class_id`) REFERENCES `student` (`id`))

-- 经过试验,没引入的id=4可以删掉的
mysql> delete from student where id=4;
Query OK, 1 row affected (1.77 sec)

mysql> insert into student values(4,'小新');
Query OK, 1 row affected (0.12 sec)

外键约束的概念

可以在创建外键的时候,对外键约束进行选择性的操作。
基本语法:add foreign key(外键字段) references 主表(主键) on 约束模式;

约束模式有三种:
1、district:严格模式,默认的,不允许操作
2、cascade:级联模式,一起操作,主表变化,从表数据跟着变化
3、set null:置空模式,主表变化(删除),从表对应记录设置为空,前提是从表中对应的外键字段允许为空

外键约束主要约束的对象是主表操作:从表就是不能插入主表不存在的数据
通常在进行约束使用的时候,需要指定操作:update和delete
常用的约束模式:on update cascade on delete set null;更新级联,删除置空(主表数据更新,那么从表数据也会更新,主表删除数据时,从表显示置空,即null)

-- 外键约束
mysql> alter table foreign_key add foreign key(class_id) references student(id)
    -> on update cascade
    -> on delete set null;
Query OK, 2 rows affected (2.09 sec)
Records: 2  Duplicates: 0  Warnings: 0

-- 这里更新失败为什么呢?下面查看结构知道了有两个外键名
mysql> update student id=2 where name='小明';
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '=2 where name='小明'' at line 1

mysql> show create table foreign_key;
+-------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table       | Create Table                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
+-------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| foreign_key | CREATE TABLE `foreign_key` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(10) DEFAULT NULL,
  `class_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `class_id` (`class_id`),
  CONSTRAINT `foreign_key_ibfk_2` FOREIGN KEY (`class_id`) REFERENCES `student` (`id`) ON DELETE SET NULL ON UPDATE CASCADE,
  CONSTRAINT `foreign_key_ibfk_1` FOREIGN KEY (`class_id`) REFERENCES `student` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 |
+-------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

-- 删除一个默认有严格约束的外键名
mysql> alter table foreign_key drop foreign key foreign_key_ibfk_1;
Query OK, 2 rows affected (1.96 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> show create table foreign_key;
+-------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table       | Create Table                                                                                                                                                                                                                                                                                                                                                                      |
+-------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| foreign_key | CREATE TABLE `foreign_key` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(10) DEFAULT NULL,
  `class_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `class_id` (`class_id`),
  CONSTRAINT `foreign_key_ibfk_2` FOREIGN KEY (`class_id`) REFERENCES `student` (`id`) ON DELETE SET NULL ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 |
+-------------+-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

-- 现在可以看到主表student更新id为6时,从表foreign_key自动更新为6(更新级联)
mysql> update student set id=6 where id=2;
Query OK, 1 row affected (0.12 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from foreign_key;
+----+------+----------+
| id | name | class_id |
+----+------+----------+
|  1 | 张三 |        1 |
|  2 | 李四 |        6 |
+----+------+----------+
2 rows in set (0.00 sec)

-- 主表student删除id=1的信息时,从表foreign_key自动置空(删除置空)
mysql> delete from student where id=1;
Query OK, 1 row affected (1.84 sec)

mysql> select * from foreign_key;
+----+------+----------+
| id | name | class_id |
+----+------+----------+
|  1 | 张三 |     NULL |
|  2 | 李四 |        6 |
+----+------+----------+
2 rows in set (0.00 sec)

约束作用

保证数据的完整性:主表与从表的数据要一致

正是因为外键有非常强大的数据约束作用,而且可能导致数据在后台变化的不能控。导致程序在进行设计开发逻辑的时候,没有办法去很好的把握数据(业务),所以外键比较少使用。
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL是一种关系型数据库管理系统,它采用了主键和外键来定义和维护表之间的关系。主键是用来唯一标识表中每一行的字段,而外键用来建立不同表之间的联系。下面是一段关于MySQL基础主键和外键的代码使用视频的介绍。 视频开始,首先介绍了如何在MySQL中创建表并定义主键。代码示例展示了CREATE TABLE语句的使用,其中指定了主键的字段和约束。然后,视频展示了如何插入数据到表中,并强调了主键字段的唯一性,以及如何处理主键冲突的情况。接着,视频演示了如何使用主键来查询特定的行,并展示了如何使用主键字段来进行排序和过滤结果。 接下来,视频转向外键的介绍。首先,视频展示了如何在创建表定义外键的语法。代码示例中,在CREATE TABLE语句中使用了FOREIGN KEY约束来指定外键的字段和参考的表,强调了外键的一致性要求。然后,视频演示了如何插入数据到含有外键的表中,并介绍了外键约束的作用。视频中还展示了如何使用外键来查询关联的数据,并且强调了外键的引用完整性。 接着,视频讲解了如何使用ALTER TABLE语句来修改表的结构和添加外键。代码示例中,视频展示了如何使用ALTER TABLE ADD CONSTRAINT语句来添加外键约束,并强调了外键的限制条件。最后,视频提醒了在删除表需要注意外键的处理,示范了如何使用ALTER TABLE DROP CONSTRAINT语句来删除外键约束。 通过这段视频的介绍,观众可以了解到MySQL中主键和外键的基本概念和用法。视频提供了代码示例和演示,帮助观众更好地理解如何在MySQL中使用主键和外键来建立表之间的关系,并展示了如何通过主键和外键来实现数据的查询和一致性要求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值