• 表关系


    一、字段操作

    ​ 1.创建:

    mysql>: create table t1(
    		id int primary key auto_increment,
    		x int,
    		y int
    );
    

    ​ 2.修改:

    mysql>: alter table t1 modify x char(4) default '';
    mysql>: alter table t1 change y z char(4) default'';
    

    ​ 3.增加

    # 末尾添加
    mysql>: alter table 表名 add 字段名 类型[(长度)约束];
    
    # 首位添加
    mysql>: alter table 表名 add 字段名 类型[(长度)约束] first;
    
    # 某字段后
    mysql>: alter table 表名 add 字段名 类型[(长度)约束] after 字段名;
    

    ​ 4.删除字段

    mysql>: alter table 表名 drop 字段名;
    

    二、多表关系

    ​ 社会中存储需要可以构建成表的数据, 它们形成的表,往往之间存储某种或某些社会关系,mysql数据库建立表结构就是社会中产生的各种数据, 分门别类管理,但mysql建立的(代码层次的)表之间, 同样需要处理表与表之间的关系,形成了 多对一 、多对多、一对一 三种关系。

    2.1 一对一

    ​ 一对一关系中,外键是建立表与表关联的字段,通常一个表的外键是另一个表的主键。而且外键在任何一方都可以,要设置成唯一键。

    2.2 一对多

    ​ 一对多的关系中,外键放在字段多的一方,此时的外键不是唯一键。

    2.3 多对多

    ​ 多对多关系中,一定要创建第三张表(关系表),每个外键都不唯一,可以看做成多个外键建立联合唯一。

    三、外键

    ​ 如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键。由此可见,外键表示了两个关系之间的相关联系。以另一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表。外键又称作外关键字。

    ​ 外键的字段名可以自定义,通常命名规范是使用关联表——关联字段的方式。

    ​ 外键要通过 foreign key 语法建立表与表之间的关系。

    ​ 使用方法:foreign key(所在表的外键字段) references 关联表(关联字段)

    mysql>: foreign key(datail_id) references t1(id)
    

    ​ 级联关系:1.级联更新: on update cascade;2.级联删除 on delete cascade。

    ​ 注意:外键字段本身可以唯一或者不唯一,但是外键关联的字段一定唯一!!!

    四、一对一无级联关系

    # 作者详情(author_detail): id,info,address
    create table author_detail(
    	id int primary key auto_increment,
        info varchar(256),
        address varchar(256)
    );
    
    # 作者表id,name,sex,age,mobile, detail_id
    create table author(
    	id int primary key auto_increment,
        name varchar(64) not null,
        mobile char(11) unique not null,
        sex enum('男', '女') default '男',
        age int default 0,
        detail_id int unique not null,
        foreign key(detail_id) references author_detail(id)
    );
    
    # 必须先创建被关联表数据,有关联表外键关联的记录后,关联表才可以创建数据
    mysql>: insert into author_detail(info,address) values('Tom_info','Tom_address');
    mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);
    mysql>: insert into author_detail(info,address) values('Bob_info','Bob_address');
    mysql>: insert into author(name,mobile,detail_id) values('Bob','15666882233', 2);
    
    # 修改关联表 author
    mysql>: insert into author_detail(info,address) values('Tom_info_sup','Tom_address_sup');
    mysql>: update author set detail_id=3 where detail_id=2; # 有未被其他数据关联的数据,就可以修改
    # 删除关联表 author
    mysql>: delete from author where detail_id=3;  # 直接删除
    
    # 修改被关联表 author_detail
    mysql>: update author_detail set id=10 where id=1;  # 无法修改
    # 删除被关联表 author_detail
    mysql>: delete from author_detail where id=1;  # 无法删除
    
    # 没有级联关系下:
    # 增加:先增加被关联表记录,再增加关联表记录
    # 删除:先删除关联表记录,再删除被关联表记录
    # 更新:关联与被关联表都无法完成 关联的外键和主键 数据更新 - (如果被关联表记录没有被绑定,可以修改)		
    

    五、一对一有级联关系

    mysql>: drop table author;
    mysql>: drop table author_detail;
    
    
    # 作者详情(author_detail): id,info,address
    create table author_detail(
    	id int primary key auto_increment,
        info varchar(256),
        address varchar(256)
    );
    
    # 作者表id,name,sex,age,mobile, detail_id
    create table author(
    	id int primary key auto_increment,
        name varchar(64) not null,
        mobile char(11) unique not null,
        sex enum('男', '女') default '男',
        age int default 0,
        detail_id int unique not null,
        foreign key(detail_id) references author_detail(id)
        on update cascade 
        on delete cascade
    );
    
    
    
    # 必须先创建被关联表数据,有关联表外键关联的记录后,关联表才可以创建数据
    mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);  # 错误
    mysql>: insert into author_detail(info,address) values('Tom_info','Tom_address');
    mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 1);
    mysql>: insert into author_detail(info,address) values('Bob_info','Bob_address');
    mysql>: insert into author(name,mobile,detail_id) values('Bob','15666882233', 2);
    
    # 修改关联表 author
    mysql>: update author set detail_id=3 where detail_id=2;  # 失败,3详情不存在
    mysql>: update author set detail_id=1 where detail_id=2;  # 失败,1详情已被关联
    mysql>: insert into author_detail(info,address) values('Tom_info_sup','Tom_address_sup');
    mysql>: update author set detail_id=3 where detail_id=2; # 有未被其他数据关联的数据,就可以修改
    # 删除关联表 author
    mysql>: delete from author where detail_id=3;  # 直接删除
    
    # 修改被关联表 author_detail
    mysql>: update author_detail set id=10 where id=1;  # 级联修改,同步关系关联表外键
    
    # 删除被关联表 author_detail
    mysql>: delete from author where detail_id=10;  # 可以删除对被关联表无影响
    mysql>: insert into author(name,mobile,detail_id) values('Tom','13344556677', 10);
    mysql>: delete from author_detail where id=10;  # 可以删除,将关联表的记录级联删除掉
    

    六、一对多

    # 一对多:外键必须放在多的一方,此时外键值不唯一
    
    # 出版社(publish): id,name,address,phone
    create table publish(
    	id int primary key auto_increment,
        name varchar(64),
        address varchar(256),
        phone char(20)
    );
    
    # 书(book):id,name,price,publish_id, author_id
    create table book(
    	id int primary key auto_increment,
        name varchar(64) not null,
        price decimal(5, 2) default 0,
        publish_id int,  # 一对多的外键不能设置唯一
        foreign key(publish_id) references publish(id)
        on update cascade
        on delete cascade
    );
    
    # 增:先增加被关联表(publish)的数据,再增加关联表(book)的数据
    mysql>: insert into publish(name, address, phone) values
    ('人民出版社', '北京', '010-110'),
    ('西交大出版社', '西安', '010-119'),
    ('老男孩出版社', '上海', '010-120');
    
    mysql>: insert into book(name, price, publish_id) values
    ('西游记', 6.66, 1),
    ('东游记', 8.66, 1),
    ('python从入门到入土', 2.66, 2),
    ('轮程序员修养之道', 3.66, 3),
    ('好好活着', 88.88, 3);
    # 没有被关联的字段,插入依旧错误
    mysql>: insert into book(name, price, publish_id) values ('打脸之道', 0.3, 4);  # 失败
    
    
    # 更新:直接更新被关联表的(publish) 主键,关联表(book) 外键 会级联更新
    mysql>: update publish set id=10 where id=1;
    # 更新:直接更新关联表的(book) 外键,修改的值对应被关联表(publish) 主键 如果存在,可以更新成功,反之失败
    mysql>: update book set publish_id=2 where id=4;  # 成功
    mysql>: update book set publish_id=1 where id=4;  # 失败
    
    
    # 删:
    #	删被关联表,关联表会被级联删除
    mysql>: delete from publish where id = 2;
    
    #	删关联表,被关联表不会发生变化
    mysql>: delete from book where publish_id = 3;
    
    # 假设:书与作者也是 一对多 关系,一个作者可以出版多本书
    create table book(
    	id int primary key auto_increment,
        name varchar(64) not null,
        price decimal(5, 2) default 0,
        publish_id int,  # 一对多的外键不能设置唯一
        foreign key(publish_id) references publish(id)
        on update cascade
        on delete cascade
        
        # 建立与作者 一对多 的外键关联
        author_id int,  
        foreign key(author_id) references author(id)
        on update cascade
        on delete cascade
    );
    

    七、多对多

    # 多对多:一定要创建第三张表(关系表),每一个外键值不唯一,看可以多个外键建立联合唯一
    
    mysql>: drop table author;
    mysql>: drop table author_detail;
    mysql>: drop table book;
    mysql>: drop table publish;
    
    # 作者(author):id, name, age
    create table author(
    	id int primary key auto_increment,
        name varchar(64),
        age int unsigned default 0
    );
    
    # 出版社(publish):id, name, address
    create table publish(
    	id int primary key auto_increment,
        name varchar(64),
        address varchar(256)
    );
    
    # 作者与出版社关系表:id, author_id, publish_id
    create table author_publish(
    	id int primary key auto_increment,
        # 关系表一定有多个外键,关联着多张表
        # 关联作者表
        author_id int,
        foreign key(author_id) references author(id)
        on update cascade
        on delete cascade,
        # 关联出版社表
        publish_id int,
        foreign key(publish_id) references publish(id)
        on update cascade
        on delete cascade,
        # 建立两个字段的联合唯一
        unique(author_id, publish_id)
    );
    
    # 注:关系表 关联着 作者 和 出版社 两张表,在表结构上 作者 与 出版社 两表键没有任何关系
    
    
    # 增:两张被关联表,没有前后关系,但关系表必须在两个表都提供数据后才能进行 关系匹配
    mysql>: insert into author(name, age) values('ruakei', 67),('engo', 76),('Lxx', 3);
    mysql>: insert into publish(name, address) values('老男孩出版社', '上海'),('小女孩出版社', '北京');
    
    # 操作关系表:
    mysql>: insert into author_publish(author_id, publish_id) values(1,1),(1,2),(2,1),(2,2),(3,1);
    
    # 关系表操作:增、删、改,只要两张被关系表有提供对应的操作数据,都可以操作成功,且对两张被关系表没有影响
    
    
    # 操作两张被关系表:
    #		增:不会影响关系表
    mysql>: insert into publish(name, address) values('西交大出版社', '西安');
    #		改:关系表都会级联更新
    mysql>: update publish set id=10 where id=1;
    #		删:关系表都会级联删除
    mysql>: delete from author where name='ruakei';
    
  • 相关阅读:
    Leetcode 538. Convert BST to Greater Tree
    Leetcode 530. Minimum Absolute Difference in BST
    Leetcode 501. Find Mode in Binary Search Tree
    Leetcode 437. Path Sum III
    Leetcode 404. Sum of Left Leaves
    Leetcode 257. Binary Tree Paths
    Leetcode 235. Lowest Common Ancestor of a Binary Search Tree
    Leetcode 226. Invert Binary Tree
    Leetcode 112. Path Sum
    Leetcode 111. Minimum Depth of Binary Tree
  • 原文地址:https://www.cnblogs.com/tangceng/p/11581155.html
Copyright © 2020-2023  润新知