zoukankan      html  css  js  c++  java
  • mysql之字段的修改,添加、删除,多表关系(外键),单表详细操作(增删改)

    字段的修改、添加和删除

    create table tf1(
    
        id int primary key auto_increment,
        x int,
        y int
    
    );
    
    #修改
    alter table tf1 modify x char(4) default'';
    alter table tf1 change y m char(4) default '';
    
    #增加
    alter table 表名 add 字段名 类型[(长度) 约束];
    >:alter table student add name char(4) first;
    >:alter table student add age int unsigned after name;
    
    #删除
    alter table 表名 drop 字段名;
    >: alter table student drop age;
    

    外键

    '''
    作者(author):id,name, sex, age, mobile, author_id
    作者详情(author_detail):id, info, address
    '''
    
    
    # 外键:通常命名规范是(关联表_关联字段)
    
    # 语法:foreign key(所在表的外键字段) references 关联表(关联字段)
    # 在作者详情表中写 eg: foreign key(author_id) references author_detail(id);
    
    #级联关系
    '''
    级联更新:on update cascade
    #就是说,A和B之间用外键a进行了关联,那么我对A中的外键a修改成b,那么B中的主键也会被修改,例如语句:update author_detail set id=10 where id=1;则会把author_detail表中id为1的字段设置为id为10,相对应的author表中选择id=1当做外键的字段也会把外键author_id设置为10.
    
    
    级联删除:on delete cascade
    #比如,学生表中学生A的主键是id=2,成绩表中有外键student_id=2,那么我们用语句:delete from student where id = 2,这样在成绩表里面学生A的记录就全部删掉了。
    '''
    

    多表关系

    """
    一对一:就是一一对应的关系,比如丈夫和妻子,作者和作者详情
    一对多:就是一个和多个对应的关系,比如部门和员工,书籍和出版社
    多对多:就是多个和多个之间进行对应,比如老师和班级,出版社和作者
    """
    
    #外键就是 建立表与表关联的字段, 通常 一个表的外键是另外一个表的主键(唯一键也可以), 例如在多对多对应的中,K1是老师A的外键,那么K1就可以在班级表中唯一的确定一个班级(即K1是班级的主键)
    
    #外键值就是外键在表中对应的主键值
    
    '''
    一对一:外键在任何一方都可以,此时外键要设置成唯一键,例如作者和作者详情:Q是作者A的外键,那Q在作者详情表中一定是唯一确定的
    
    一对多:外键必须放在多的一方,外键值是不唯一的,例如书和出版社:Q是书A的外键,Q也就出版社的主键,唯一确定一个出版社P,但是P可能还出版了书B,而B同样有外键Q,这样Q的外键值就包括了A和B了。
    
    多对多:一定要创建第三张表(关系表),每一个外键值不唯一,还可以多个外键值联合唯一, 例如作者和出版社,
    
    		作者(author):id, name, age
            出版社(publish):id, name, address
            作者与出版社关系表:id, author_id, publish_id
            id		author_id		publish_id
            1			1				1
            2			1				2
            3			2				1
            4			2				2
            
    从上面可以看出,关系表的外键A是作者表的主键,可以唯一确认一个作者,外键B是出版社表的主键,可以唯一确认一个出版社,这样A和B的组合就可以是联合唯一了,即在第三张表中唯一确认。
    '''
    
    
    

    单表详细操作:增删改

    一对一:无级联关系

    # 作者详情(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详情不存在(此处是关联表,即把第id为2的字段修改为id=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';
    
  • 相关阅读:
    Java读取Excel文件(包括xls和xlsx)的样例程序
    Node.js中使用pipe拷贝大文件不能完全拷贝的解决办法
    Spring Boot中一个Servlet主动断开连接的方法
    算法学习笔记1.3.3 质因数分解
    算法学习笔记1.3.2 素数判定
    算法学习笔记1.3.1 素数筛法
    算法学习笔记1.2.2 扩展欧几里得
    算法学习笔记1.2.1 欧几里得算法
    算法学习笔记1.1.3 矩阵的逆
    Windows下Tesseract-OCR的安装
  • 原文地址:https://www.cnblogs.com/michealjy/p/11581400.html
Copyright © 2011-2022 走看看