• MySQL(10):创建和管理表


    基础知识

    在 MySQL 中,一个完整的数据存储过程总共有 4 步,分别是:创建数据库、确认字段、创建数据表、插入数据。

    在这里插入图片描述

    要先创建一个数据库,而不是直接创建数据表:从系统架构的层次上看,MySQL 数据库系统从大到小依次是:数据库服务器、数据库、 数据表、数据表的 行与列 。MySQL 数据库服务器之前已经安装。所以,从创建数据库开始。

    标识符命名规则

    • 数据库名、表名不得超过30个字符,变量名限制为29个;
    • 必须只能包含 A–Z, a–z, 0–9, _共63个字符;
    • 数据库名、表名、字段名等对象名中间不要包含空格;
    • 同一个MySQL软件中,数据库不能同名;同一个库中,表不能重名;同一个表中,字段不能重名;
    • 必须保证你的字段没有和保留字、数据库系统或常用方法冲突。如果坚持使用,请在SQL语句中使 用 ' (着重号)引起来;
    • 保持字段名和类型的一致性:在命名字段并为其指定数据类型的时候一定要保证一致性,假如数据类型在一个表里是整数,那在另一个表里可就别变成字符型了。

    MySQL中的数据类型

    类型说明
    整数类型TINYINT、SMALLINT、MEDIUMINT、INT(或INTEGER)、BIGINT
    浮点类型FLOAT、DOUBLE
    定点数类型DECIMAL
    位类型BIT
    日期时间类型YEAR、TIME、DATE、DATETIME、TIMESTAMP
    文本字符串类型CHAR、VARCHAR、TINYTEXT、TEXT、MEDIUMTEXT、LONGTEXT
    枚举类型ENUM
    集合类型SET
    二进制字符串类型BINARY、VARBINARY、TINYBLOB、BLOB、MEDIUMBLOB、LONGBLOB
    JSON类型JSON对象、JSON数组
    空间数据类型单值:GEOMETRY、POINT、LINESTRING、POLYGON;集合:MULTIPOINT、MULTILINESTRING、MULTIPOLYGON、GEOMETRYCOLLECTION
    数据类型描述
    INT从-2^31 到 2^31-1的整型数据。存储大小为 4个字节
    CHAR(size)定长字符数据。若未指定,默认为1个字符,最大长度255
    VARCHAR(size)可变长字符数据,根据字符串实际长度保存,必须指定长度
    FLOAT(M,D)单精度,占用4个字节,M=整数位+小数位,D=小数位。 D<=M<=255,0<=D<=30,默认M+D<=6
    DOUBLE(M,D)双精度,占用8个字节,D<=M<=255,0<=D<=30,默认M+D<=15
    DECIMAL(M,D)高精度小数,占用M+2个字节,D<=M<=65,0<=D<=30,最大取值范围与DOUBLE相同。
    DATE日期型数据,格式’YYYY-MM-DD’
    BLOB二进制形式的长文本数据,最大可达4G
    TEXT长文本数据,最大可达4G

    创建和管理数据库

    创建数据库

    方式1: 创建数据库

    CREATE DATABASE 数据库名;
    
    • 1
    CREATE DATABASE mytest1;
    SHOW CREATE DATABASE mytest1;
    
    • 1
    • 2

    在这里插入图片描述
    在这里插入图片描述
    方式2: 创建数据库并指定字符集’ ‘

    CREATE DATABASE 数据库名 CHARACTER SET 字符集;
    
    • 1

    在这里插入图片描述

    方式3: 判断数据库是否已经存在,不存在则创建数据库( 推荐 )

    CREATE DATABASE IF NOT EXISTS 数据库名;
    
    • 1

    DATABASE 不能改名。一些可视化工具可以改名,它是建新库,把所有表复制到新库,再删旧库完成的。

    使用数据库

    查看当前所有的数据库
    查看当前连接中的数据库都有哪些

    SHOW DATABASES; #有一个S,代表多个数据库
    
    • 1

    在这里插入图片描述

    查看当前正在使用的数据库

    SELECT DATABASE();  #使用的一个 mysql 中的全局函数
    
    • 1

    在这里插入图片描述

    查看指定库下所有的表

    SHOW TABLES FROM 数据库名;
    
    • 1

    SHOW

    查看数据库的创建信息

    SHOW CREATE DATABASE 数据库名;
    # 或者:
    SHOW CREATE DATABASE 数据库名\G
    
    • 1
    • 2
    • 3

    在这里插入图片描述

    使用/切换数据库

    USE 数据库名;
    
    • 1

    在这里插入图片描述

    要操作表格和数据之前必须先说明是对哪个数据库进行操作,否则就要对所有对象加上“数据库名.”。

    修改数据库

    更改数据库字符集

    ALTER DATABASE 数据库名 CHARACTER SET 字符集;  #比如:gbk、utf8等
    
    • 1

    在这里插入图片描述

    删除数据库

    方式1: 删除指定的数据库

    DROP DATABASE 数据库名;
    
    • 1

    在这里插入图片描述

    方式2: 删除指定的数据库( 推荐 )

    DROP DATABASE IF EXISTS 数据库名;
    
    • 1

    在这里插入图片描述

    创建表

    创建方式1

    必须具备:
    1.CREATE TABLE权限
    2.存储空间
    语法格式:

    CREATE TABLE [IF NOT EXISTS] 表名(
    字段1, 数据类型 [约束条件] [默认值],
    字段2, 数据类型 [约束条件] [默认值],
    字段3, 数据类型 [约束条件] [默认值],
    ……
    [表约束条件]
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    加上了IF NOT EXISTS关键字,则表示:如果当前数据库中不存在要创建的数据表,则创建数据表;如果当前数据库中已经存在要创建的数据表,则忽略建表语句,不再创建数据表。

    必须指定:
    1.表名
    2.列名(或字段名),数据类型,长度
    可选指定:
    1.约束条件
    2.默认值

    CREATE TABLE IF NOT EXISTS myemp1(   #需要用户具备创建表的权限。
    id INT,
    emp_name VARCHAR(15), #使用VARCHAR来定义字符串,必须在使用VARCHAR时指明其长度。
    hire_date DATE
    );
    #查看表结构
    DESC myemp1;
    #查看创建表的语句结构
    SHOW CREATE TABLE myemp1; #如果创建表时没有指明使用的字符集,则默认使用表所在的数据库的字符集。
    #查看表数据
    SELECT * FROM myemp1;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在这里插入图片描述

    创建方式2

    使用 AS subquery 选项,将创建表和插入数据结合起来
    在这里插入图片描述
    指定的列和子查询中的列要一一对应
    通过列名和默认值定义列

    CREATE TABLE emp1 AS SELECT * FROM employees;
    CREATE TABLE emp2 AS SELECT * FROM employees WHERE 1=2; -- 创建的emp2是空表
    
    • 1
    • 2
    CREATE TABLE myemp2
    AS
    SELECT employee_id,last_name,salary
    FROM employees;
    
    DESC myemp2;
    DESC employees;
    
    SELECT *
    FROM myemp2;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在这里插入图片描述

    查看数据表结构

    在MySQL中创建好数据表之后,可以查看数据表的结构。MySQL支持使用 DESCRIBE/DESC 语句查看数据表结构,也支持使用 SHOW CREATE TABLE 语句查看数据表结构。

    SHOW CREATE TABLE 表名\G
    
    • 1

    使用SHOW CREATE TABLE语句不仅可以查看表创建时的详细语句,还可以查看存储引擎和字符编码。

    修改表

    修改表指的是修改数据库中已经存在的数据表的结构

    • 使用 ALTER TABLE 语句可以实现:
    • 向已有的表中添加列;
    • 修改现有表中的列;
    • 删除现有表中的列;
    • 重命名现有表中的列。

    追加一个列

    ALTER TABLE 表名 ADDCOLUMN】 字段名 字段类型 【FIRST|AFTER 字段名】;
    
    • 1
    ALTER TABLE myemp1
    ADD phone_number VARCHAR(20) FIRST;
    
    • 1
    • 2

    在这里插入图片描述

    修改一个列

    可以修改列的数据类型,长度、默认值和位置
    修改字段数据类型、长度、默认值、位置的语法格式如下:

    ALTER TABLE 表名 MODIFYCOLUMN】 字段名1 字段类型 【DEFAULT 默认值】【FIRST|AFTER 字段名2;
    
    • 1
    ALTER TABLE myemp1
    MODIFY emp_name VARCHAR(25) ;
    
    ALTER TABLE myemp1
    MODIFY emp_name VARCHAR(35) DEFAULT 'aaa';
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    重命名一个列

    使用 CHANGE old_column new_column dataType子句重命名列。语法格式如下:

    ALTER TABLE 表名 CHANGE 【column】 列名 新列名 新数据类型;
    
    • 1
    ALTER TABLE myemp1
    CHANGE salary monthly_salary DOUBLE(10,2);
    
    • 1
    • 2

    在这里插入图片描述

    删除一个列

    删除表中某个字段的语法格式如下:

    ALTER TABLE 表名 DROP [COLUMN] 字段名
    SHOW DATABASES;
    
    • 1
    • 2
    ALTER TABLE myemp1
    DROP COLUMN my_email;
    
    • 1
    • 2

    在这里插入图片描述

    重命名表

    方式一: 使用RENAME

    RENAME TABLE emp
    TO myemp;
    
    • 1
    • 2

    方式二:

    ALTER table dept
    RENAME [TO] detail_dept;  -- [TO]可以省略
    
    • 1
    • 2

    删除表

    • 在MySQL中,当一张数据表 没有与其他任何数据表形成关联关系 时,可以将当前数据表直接删除;
    • 数据和结构都被删除;
    • 所有正在运行的相关事务被提交;
    • 所有相关索引被删除;
    • 语法格式:

    IF EXISTS 的含义为:如果当前数据库中存在相应的数据表,则删除数据表;如果当前数据库中不存在相应的数据表,则忽略删除语句,不再执行删除数据表的操作。
    举例:DROP TABLE 语句不能回滚。

    清空表

    TRUNCATE TABLE语句:

    • 删除表中所有的数据;
    • 释放表的存储空间
      举例:TRUNCATE TABLE detail_dept;
      TRUNCATE语句不能回滚,而使用 DELETE 语句删除数据,可以回滚

    DCL中COMMIT与ROLLBACK的使用

    COMMIT:提交数据。一旦执行COMMIT,则数据就被永久的保存在了数据库中,意味着数据不可以回滚。
    ROLLBACK:回滚数据。一旦执行ROLLBACK,则可以实现数据的回滚。回滚到最近的一次COMMIT之后。

    DELETE FROM emp2;
    #TRUNCATE TABLE emp2;
    SELECT * FROM emp2;
    ROLLBACK;
    SELECT * FROM emp2;
    
    • 1
    • 2
    • 3
    • 4
    • 5

    TRUNCATE TABLEDELETE 速度快,且使用的系统和事务日志资源少,但 TRUNCATE 无事务且不触发 TRIGGER,有可能造成事故,故不建议在开发代码中使用此语句。
    说明:TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同。

    DDL 和 DML 的说明

    ① DDL的操作一旦执行,就不可回滚。指令SET autocommit = FALSE对 DDL 操作失效。(因为在执行完 DDL 操作之后,一定会执行一次COMMIT。而此COMMIT操作不受SET autocommit = FALSE影响的。)
    ② DML的操作默认情况,一旦执行,也是不可回滚的。但是,如果在执行DML之前,执行了 SET autocommit = FALSE,则执行的 DML 操作就可以实现回滚。

    拓展

    表删除 操作将把表的定义和表中的数据一起删除,并且MySQL在执行删除操作时,不会有任何的确认信息提示,因此执行删除操时应当慎重。在删除表前,最好对表中的数据进行 备份 ,这样当操作失误时可以对数据进行恢复,以免造成无法挽回的后果。
    同样的,在使用 ALTER TABLE 进行表的基本修改操作时,在执行操作过程之前,也应该确保对数据进行完整的 备份 ,因为数据库的改变是 无法撤销 的,如果添加了一个不需要的字段,可以将其删除;相同的,如果删除了一个需要的列,该列下面的所有数据都将会丢失。

    新特性

    在MySQL 8.0版本中,InnoDB表的DDL支持事务完整性,即 DDL操作要么成功要么回滚 。DDL操作回滚日志写入到data dictionary数据字典表mysql.innodb_ddl_log(该表是隐藏的表,通过show tables无法看到)中,用于回滚操作。通过设置参数,可将DDL操作日志打印输出到MySQL错误日志中。

    数据库学习视频:
    【MySQL数据库入门到大牛,mysql安装到优化,百科全书级,全网天花板】

  • 相关阅读:
    化整为零优化重用,Go lang1.18入门精炼教程,由白丁入鸿儒,go lang函数的定义和使用EP07
    B树与B+树与Mysql innodb的B+树和其相关索引
    Django 创建好的模块怎么在后台显示
    网络编程 - IP协议
    Jmeter(十六):jmeter场景的运行架构&配置远程负载机详解
    MySql数据库基础篇-增删改查
    .NET Core/.NET6 使用DbContext 连接数据库,SqlServer
    DIM层维度表学习之用户维度表分析
    AE是最好的特效软件吗?
    Kubernetes-23:详解如何将CPU Manager做到游刃有余
  • 原文地址:https://blog.csdn.net/FDS99999/article/details/134233981