[Mysql] Mysql的多表查询----多表关系(下)

4、操作

方式二:创建表之后设置外键约束

外键约束也可以在修改表时添加,但是添加外键约束的前提是:从表中外键列中的数据必须与主表中主键列中的数据一致或者是没有数据。

语法:

alter table <从表名> add constraint <外键名> foreign key (<列名>) references <主表名> (<列名>);

创建主表:

创建从表:

创建外键约束:

5、数据插入

注意:当主表和从表有外键约束是,给主表和从表添加数据时,必须先给主表添加数据。

(1)给主表添加数据

(2)给从表添加数据

注意:注意给从表添加数据时,外键列的值不能随便写,必须依赖主表的主键列--即:外键列中的值只能是主键列上的值。

6、删除数据

注意:

(1)主表的数据被从表依赖时(即:主列中的值在外列中的值出现)时,不能删除,否则可以删除。

(2)从表的数据可以随便删除。

例如:

1、

2、

注意:删除表时,只能先删除从表,再删除主表。

7、删除外检约束

当一个表不需要外键约束时,就需要从表将其删除。外键一旦删除,就会解除主表和从表间的关联关系。

格式:

alter table <从表名> drop foreign key <外键约束名> ;

实现:

相关推荐
JioJio~z11 分钟前
MYSQL之创建数据库和表
数据库·mysql
RainbowSea1 小时前
6. MySQL 索引的数据结构(详细说明)
数据库·sql·mysql
jk_1011 小时前
MATLAB中strip函数用法
java·服务器·数据库
XiYang-DING1 小时前
【数据库系统概论】第七章 数据库设计
数据库
尘鹄2 小时前
一文讲懂Go语言如何使用配置文件连接数据库
开发语言·数据库·后端·golang
窜天猴牛逼2 小时前
IO多路复用(epoll)/数据库(sqlite)
数据库
老哥不老2 小时前
结合 Pandas 使用 SQLite3 实战
数据库·sqlite·pandas
eddie_k22 小时前
MySQL主从架构配合ShardingJdbc实现读写分离
数据库·mysql·架构
八股文领域大手子5 小时前
责任链模式+策略模式在项目中的实践
java·数据库·redis·sql·mysql
亥时科技6 小时前
园区环境数字化管理系统(源码+文档+讲解+演示)
java·数据库·开源·源代码管理