11-MySQL--外键(增加外键+修改/删除外键+外键的作用+外键的条件+外键约束)+联合查询+子查询(按位置分类:from/where/exists子查询+按结果分类:标量/列/行/表子查询)

本文详细介绍了MySQL中的外键概念、创建与删除、作用及约束条件,探讨了联合查询的基本语法和应用场景,并对子查询的分类、用法进行了深入解析。
摘要由CSDN通过智能技术生成

一、外键

1、外键:foreign key。如果一张表中有一个字段(非主键)指向另外一张表的主键,将该字段称为外键

注:外键必须指向另外一张表,即 和另外一张表产生联系

2、关系型数据库有两种约束,一种是约束实体内部字段与字段之间的关系,一种是约束实体与实体之间的关系(用外键来控制)

3、一张表可以有多个外键

4、增加外键

(1)外键可以在创建表的时候或者创建表之后增加

(2)在创建表的时候增加外键:在所有的表字段之后,使用"foreign key(外键字段) references 外部表(主键字段)"

注:创建表时增加外键只有一种方法,就是在所有字段之后增加外键。不能直接在外键字段后面加"foreign key references 外部表(主键字段)"

    -- 在创建表的时候增加外键
    create table my_foreign1(
        id int primary key auto_increment,
        name varchar(20) not null comment '学生姓名',
        c_id int comment '班级id',    -- 普通字段
        -- 增加外键
        foreign key(c_id) references my_class(id)
    )charset utf8;

    -- 查看表结构
    desc my_foreign1;

    -- 查看表创建语句
    show create table my_foreign1;

注:外键要求字段本身必须先是一个索引(普通索引)。如果字段本身没有索引,外键会先创建一个索引,然后才会创建外键本身

(3)在创建表之后增加外键:修改表结构

注:

a). 外键字段本身要先在表中存在,否则增加外键时会报错

b). 外键名字必须未被使用过,其他表也没有使用过才可以。所以,使用默认的外键名比较靠谱???

    -- 在创建表之后增加外键:修改表结构
    -- 外键字段本身要先存在
    -- 外键名字必须未被使用过,其他表也没有使用过才可以
    alter table 表名 add [constraint 外键名字] foreign key(外键字段) references 外部表(主键字段);
    -- 创建表
    create table my_foreign2(
        id int primary key auto_increment,
        name varchar(20) not null comment '学生姓名',
        c_id int comment '班级id'    -- 普通字段
    )charset utf8;

    -- 查看表结构
    desc my_foreign2;
    
    -- 增加外键(在创建表之后增加外键:修改表结构)
    alter table my_foreign2 add constraint student_class_1 foreign key(c_id) references my_class(id);

    -- 查看表结构
    desc my_foreign2;

    -- 查看表创建语句
    -- 外键名字是"[constraint 外键名字]"中定义的"student_class_1"
    show create table my_foreign2;
    

5、修改外键&删除外键

(1)外键不可修改,只能先删除后新增

&

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值