• Mysql之库、表、记录相关操作2


    Mysql之库、表、记录相关操作2

    参考:http://www.cnblogs.com/linhaifeng/articles/7232894.html#_label6

    一、修改表

    语法:
    1. 修改表名
          ALTER TABLE 表名 
                              RENAME 新表名;
    
    2. 增加字段
          ALTER TABLE 表名
                              ADD 字段名  数据类型 [完整性约束条件…],
                              ADD 字段名  数据类型 [完整性约束条件…];
          ALTER TABLE 表名
                              ADD 字段名  数据类型 [完整性约束条件…]  FIRST;
          ALTER TABLE 表名
                              ADD 字段名  数据类型 [完整性约束条件…]  AFTER 字段名;
                                
    3. 删除字段
          ALTER TABLE 表名 
                              DROP 字段名;
    
    4. 修改字段
          ALTER TABLE 表名 
                              MODIFY  字段名 数据类型 [完整性约束条件…];
          ALTER TABLE 表名 
                              CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];
          ALTER TABLE 表名 
                              CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];
    

    eg:

    示例:
    1. 修改存储引擎
    mysql> alter table service 
        -> engine=innodb;
    
    2. 添加字段
    mysql> alter table student10
        -> add name varchar(20) not null,
        -> add age int(3) not null default 22;
        
    mysql> alter table student10
        -> add stu_num varchar(10) not null after name;                //添加name字段之后
    
    mysql> alter table student10                        
        -> add sex enum('male','female') default 'male' first;          //添加到最前面
    
    3. 删除字段
    mysql> alter table student10
        -> drop sex;
    
    mysql> alter table service
        -> drop mac;
    
    4. 修改字段类型modify
    mysql> alter table student10
        -> modify age int(3);
    mysql> alter table student10
        -> modify id int(11) not null primary key auto_increment;    //修改为主键
    
    5. 增加约束(针对已有的主键增加auto_increment)
    mysql> alter table student10 modify id int(11) not null primary key auto_increment;
    ERROR 1068 (42000): Multiple primary key defined
    
    mysql> alter table student10 modify id int(11) not null auto_increment;
    Query OK, 0 rows affected (0.01 sec)
    Records: 0  Duplicates: 0  Warnings: 0
    
    6. 对已经存在的表增加复合主键
    mysql> alter table service2
        -> add primary key(host_ip,port);        
    
    7. 增加主键
    mysql> alter table student1
        -> modify name varchar(10) not null primary key;
    
    8. 增加主键和自动增长
    mysql> alter table student1
        -> modify id int not null primary key auto_increment;
    
    9. 删除主键
    a. 删除自增约束
    mysql> alter table student10 modify id int(11) not null; 
    
    b. 删除主键
    mysql> alter table student10                                 
        -> drop primary key;
    

    二、复制表

    create table 新表名 like 旧表名;
    eg:1
    create table nt like tt; # 将tt的表结构复制到新表nt中, 约束条件一并复制
    eg:2
    create table nt1 select * from tt where 1=2; # 将tt的表结构复制到新表nt1中, 约束条件不会复制
    
    # 结构+数据
    create table 新表名 select * from 旧表名;
    注: 会复制表结构+数据, 但不会复制约束条件
    

    三、删除表

    DROP TABLE 表名;
    

    四、表中字段的详细操作

    create table t2(
    	id int primary key auto_increment,
        x int,
        y int
    );
    insert into t2(x, y) values(10, 20), (100, 200), (1000, 2000);
    
    '''
    1.修改字段信息
    alter table 表名 modify 字段名 类型[(宽度) 约束];
    alter table t2 modify x bigint default 0;  # 模式不同, 涉及精度问题
    
    2.修改字段名及信息
    alter table 表名 change 旧字段名 新字段名 类型[(宽度) 约束];
    alter table t2 change y c char(10) not null; # 模式不同, 涉及类型转换问题
    
    3.添加字段名
    # 末尾添加
    alter table 表名 add 字段名 类型[(宽度) 约束], ..., add 字段名 类型[(宽度) 约束];
    alter table t2 add age int, add gender enum("male", "female", "wasai") default "wasai";
    
    # 首尾添加
    alter table 表名 add 字段名 类型[(宽度) 约束] first;
    # 指定位添加:指定字段后
    alter table 表名 add 字段名 类型[(宽度) 约束] after 旧字段名;
    alter table t2 add y int after x;
    
    4.删除字段名
    alter table 表名 drop 字段名;
    alter table t2 drop y;
    '''
    

    五、特殊表(mysql.user)=>用户管理

    # 操作前提:登录root用户
    
    1.重要字段
    Host | User | Password
    
    2.新建用户
    create user 用户名@主机名 identified by '密码'; # 正确
    create user zero@localhost identified by 'zero';
    
    注:insert into mysql.user(Host,User,Password) values("主机名","用户名",password("密码")); # 错误
    
    3.设置用户权限
    grant 权限们 on 数据库名.表名 to 用户名@主机名 [with grant option];
    grant create on db1.* to zero@localhost with grant option;
    注:权限有select,delete,update,insert,drop..., all代表所有权限
    注:数据库名,表名可以用*替换,代表所有
    注:设置权限时如果没有当前用户,会自动创建用户,提倡使用
    重点: grant all on db1.* to owen@localhost identified by 'owen'; # (创建用户)设置权限
    
    4.撤销权限
    revoke 权限名 on 数据库名.表名 from 用户名@主机名;
    revoke delete on db1.* from owen@localhost;
    
    5.修改密码
    set password for 用户名@主机名 = password('新密码');
    set password for owen@localhost = password('123');
    
    6.删除用户
    drop user 用户名@主机名;
    

    六、表关系

    社会中存储需要可以构建成表的数据, 它们形成的表,往往之间存储某种或某些社会关系,

    mysql数据库建立表结构就是社会中产生的各种数据, 分门别类管理

    但mysql建立的(代码层次的)表之间, 同样需要处理表与表之间的关系

    形成了 多对一 | 多对多 | 一对一 三种关系

    多对一

    '''
    案例:员工employees表 | 部门department表
    
    建表规则:
    先建立主表,再建立从表,在从表中设置主表的唯一字段(通常为主键)作为外键
    
    建表语法:
    create table 主表(
    	id int primary key auto_increment,
    	...
    );
    create table dep(
    	id int primary key auto_increment,
    	name varchar(16),
    	work varchar(16)
    );
    create table 从表(
    	id int primary key auto_increment,
    	...
    	主表_id int, # 只是在从表中起了一个名字, 该名字和主表主键对应,所有起了个见名知义的名字
    	foreign key(主表_id) references 主表(唯一字段名id)
    	on update cascade
        on delete cascade
    );
    create table emp(
    	id int primary key auto_increment,
    	name varchar(16),
    	salary float,
    	dep_id int,
    	foreign key(dep_id) references dep(id)
    	on update cascade # 设置级联
    	on delete cascade
    );
    
    插入记录规则:
    先插入主表数据,再插入从表数据
    insert into dep values(1, '市场部', '销售'), (2, '教学部', '授课');
    insert into emp(name, salary, dep_id) values('egon', 3.0, 2),('yanghuhu', 2.0, 2),('sanjiang', 10.0, 1),('owen', 88888.0, 2),('liujie', 8.0, 1);
    
    更新删除数据:
    两表间相互影响,先从依赖数据入手,再进行更新删除操作
    eg:1
    删除主表dep中一个部门
    delete from dep where id=1; => 从表emp中属于该部门的员工都被删除了
    
    更新从表emp中一个员工的部门
    update emp set dep_id=3 where name='egon'; <= 部门必须存在
    insert into dep values(3, '管理部', '吃饭睡觉打豆豆, 明确团队方针');
    '''
    

    多对多

    '''
    案例:作者author表 | 书book表
    
    建表规则:
    新建第三张表,通过两个外键形成多对多关系
    
    建表语法:
    create table 表1(
        id int primary key auto_increment,
        ...
    );
    create table book(
    	id int primary key auto_increment,
    	name varchar(16),
    	price int
    );
    create table 表2(
        id int primary key auto_increment,
        ...
    );
    create table author(
    	id int primary key auto_increment,
    	name varchar(16)
    );
    create table 关系表(
        id int primary key auto_increment,
        表1_id int,
        表2_id int,
        foreign key(表1_id) references 表1(id)
        on update cascade
        on delete cascade,
        foreign key(表2_id) references 表2(id)
        on update cascade
        on delete cascade
    );
    create table book_author(
        id int primary key auto_increment,
        book_id int,
        author_id int,
        foreign key(book_id) references book(id)
        on update cascade
        on delete cascade,
        foreign key(author_id) references author(id)
        on update cascade
        on delete cascade
    );
    '''
    

    一对一

    '''
    案例:丈夫husband表 | 妻子wife表
    
    建表规则:
    未存放外键的表被依赖,称之为左表;存放外键的表示依赖表,称之为右表;先操作左边再操作右表
    
    建表语法:
    create table 左表(
        id int primary key auto_increment,
        ...
    );
    create table husband(
    	id int primary key auto_increment,
    	name varchar(16)
    );
    create table 右表(
        id int primary key auto_increment,
        ...
        左表_id int unique, # 一对一的外键需要唯一性
        foreign key(左表_id) references 左表(id)
        on update cascade
        on delete cascade
    );
    create table wife(
    	id int primary key auto_increment,
    	name varchar(16),
    	husband_id int unique, # 一对一的外键需要唯一性
    	foreign key(husband_id) references husband(id)
        on update cascade
        on delete cascade
    );
    '''
    
  • 相关阅读:
    从零开始入门 K8s | 有状态应用编排
    OAM 深入解读:OAM 为云原生应用带来哪些价值?
    你不得不了解 Helm 3 中的 5 个关键新特性
    CNCF 公布 2020 年 TOC 选举结果 | 云原生生态周报 Vol. 36
    调度系统设计精要
    Spring的IOC容器第一辑
    JavaScript工作体系中不可或缺的函数
    教你五步制作精美的HTML时钟
    web前端vertical-align的作用及对象详解
    JavaScript中常见的10个BUG及其修复方法
  • 原文地址:https://www.cnblogs.com/prodigal/p/10246761.html
Copyright © 2020-2023  润新知