当前位置: 首页 > article >正文

MySQL 10 章——创建和管理表

一、基础知识

(1)一条数据的存储过程

  1. 存储数据是处理数据的第一步。只有正确地把数据存储起来,我们才能进行有效的处理和分析
  2. 在MySQL中,一个完整的数据存储过程总共有四步
    1. 创建数据库
    2. 确认字段
    3. 创建数据表
    4. 插入数据
  3. 从系统层次架构上看,MySQL数据库系统从大到小依次是数据库服务器、数据库、数据表、数据表地行与列

(2)标识符命名规则

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

(3)MySQL中的数据类型

  1. 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

二、创建和管理数据库

(1)创建数据库

  1. 方式一:创建数据库
    CREATE DATABASE 数据库名;
  2. 方式二:创建数据库并指定字符集
    CREATE DATABASE 数据库名 CHARACTER SET 字符集;
  3. 方式三:判断数据库是否已经存在,不存在则创建数据库(推荐)
    CREATE DATABASE IF NOT EXISTS 数据库名;
  4. 在创建数据库时,如果我们没有显式指定字符集,那就默认使用utf8mb4
  5. 当我们使用方式三创建数据库时,如果MySQL中已经存在该数据库,则忽略创建语句(不会报错),
  6. 可以看到字符集:

(2)使用数据库

  1. 查看当前所有数据库
    SHOW DATABASES;
  2. 查看当前正在使用的数据库
    SELECT DATABASE();
  3. 使用/切换数据库
    USE 数据库名;
  4. 查看指定库下的所有表
    SHOW TABLES FROM 数据库名;
    或者
    SHOW TABLES;
  5. 查看数据库的创建信息
    SHOW CREATE DATABASE 数据库名;
    或者
    SHOW CREATE DATABASE 数据库名\G;

(3)修改数据库

  1. 更改数据库的字符集
    ALTER DATABASE 数据库名 CHARACTER SET 字符集;
  2. DATABASE不能改名。某些可视化工具可以给数据库改名,实际上是新建了一个库,把所有表复制到了新库,再删旧库完成的 

(4)删除数据库

  1. 删除指定的数据库
    DROP DATABASE 数据库名;
  2. 删除指定的数据库(推荐)
    DROP DATABASE IF EXISTS 数据库名;
  3. 如果要删除的数据库存在,则删除成功。如果不存在,则默默结束,不会报错 

三、创建表

(1)创建方式一

  1. 方式一:
    #例如  注意:IF NOT EXISTS是可选的
    CREATE TABLE IF NOT EXISTS myemp1(  #需要用户具备创建表的权限
    id int,
    emp_name VARCHAR(15),   #使用VARCHAR定义字符串,必须指定长度
    hire_date DATE
    );

(2)创建方式二

  1. 方式二(基于现有的表去创建新的表):
    #例如
    CREATE TABLE myemp2
    AS
    SELECT employee_id,last_name,salary
    FROM employees;    #把数据也导入进去了
    
    #例如
    CREATE TABLE myemp2
    AS
    SELECT e.employee_id emp_id,e.last_name lname,e.salary
    FROM employees e JOIN departments d
    ON e.department_id = d.department_id;
  2. 查询语句中字段的别名,可以作为新创建的表的字段的名称
  3. 此时的查询语句可以结构比较丰富,使用前面章节讲过的各种SELECT
  4. 练习:创建一个表employees_copy,实现对employees表的复制,包括表数据
    CREATE TABLE employees_copy
    AS
    SELECT *
    FROM employees;

  5. 练习:创建一个表employees_blank,实现对employees表的复制,不包括表数据
    CREATE TABLE employees_blank
    AS
    SELECT *
    FROM employees
    WHERE 1 = 2;

(3)查看数据表结构

  1. 查看表结构:
    DESC 表名;
  2. 查看创建表的语句结构:
    SHOW CREATE TABLE 表名;
  3. 如果创建表时没有指明使用的字符集,则默认使用表所在的数据库的字符集

四、修改表

(1)追加一个列

  1. 示例(默认添加到表中最后一个字段的位置):
    ALTER TABLE myemp1
    ADD salary DOUBLE(10,2);  #一共有十位,小数点后有两位

  2. 指定要添加的字段的位置:
    ALTER TABLE myemp1
    ADD phone_number VARCHAR(20) FIRST; #添加到所有字段最前面
    
    ALTER TABLE myemp1
    ADD email VARCHAR(45) AFTER emp_name; #添加到emp_name字段的后面

  3. 语法格式:
    #[FIRST/AFTER 列名]代表可选
    ALTER TABLE 表名 ADD 列名1 数据类型 [FIRST/AFTER 列名2];
  4. 从语法格式来看,数据类型是必备的,位置是可选的 

(2)修改一个列

  1. 可以修改列的数据类型、长度、默认值、位置
  2. 一般不会修改数据类型
  3. 示例:
    ALTER TABLE myemp1
    MODIFY emp_name VARCHAR(25);
    
    ALTER TABLE myemp1
    MODIFY emp_name VARCHAR(25) DEFAULT 'aaa';  #代表将默认值修改为'aaa'

  4. 语法格式: 
    #[DEFAULT 默认值] [FIRST/AFTER 列名]代表可选
    ALTER TABLE 表名 MODIFY 列名1 数据类型 [DEFAULT 默认值] [FIRST/AFTER 列名2];
  5. 从语法格式来看,数据类型是必备的,默认值和位置是可选的 

(3)重命名一个列

  1. 语法格式:
    ALTER TABLE 表名 CHANGE 列名 新列名 新数据类型;
  2. 示例:
    ALTER TABLE myemp1
    CHANGE salary monthly_salary DOUBLE(20,2);
    
    ALTER TABLE myemp1
    CHANGE email my_email VARCHAR(50);

(4)删除一个列

  1. 语法格式:
    #[COLUMN]表示可选
    ALTER TABLE 表名 DROP [COLUMN] 列名;
  2. 示例:
    ALTER TABLE myemp1
    DROP COLUMN my_email;

五、重命名表

  1. 方式一:
    RENAME TABLE myemp1
    TO myemp11;

  2. 方式二:
    ALTER TABLE myemp2
    RENAME TO myemp12;

六、删除表

  1. 语法格式:
    DROP TABLE [IF EXISTS] 数据表1 [, 数据表2, …, 数据表n];
  2. 示例:
    DROP TABLE IF EXISTS myemp12;

  3. 删除表,不光将表结构删除掉,同时删除了表中的数据,释放表空间 

七、清空表

  1. 清空表,清空表中的所有数据,但表结构保留
  2. 示例:
    TRUNCATE TABLE employees_copy;

八、内容扩展

(1)DCL中COMMIT与ROLLBACK的使用

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

(2)对比TRUNCATE TABLE(DDL)和DELETE FROM(DML)

  1. 相同点:都可以实现对表中所有数据的删除,同时保留表结构
  2. 不同点:
    1. TRUNCATE TABLE:一旦执行此操作,表数据全部清除。同时,数据是不可以回滚的
      #测试代码,一步一步执行
      CREATE TABLE myemp3
      AS
      SELECT e.employee_id emp_id,e.last_name lname,d.department_name
      FROM employees e JOIN departments d
      ON e.department_id = d.department_id;
      
      SELECT *
      FROM myemp3;
      
      COMMIT;
      
      SET autocommit = FALSE;
      
      TRUNCATE TABLE myemp3;
      
      SELECT *
      FROM myemp3;
      
      ROLLBACK;
      
      SELECT *
      FROM myemp3;
    2. DELETE FROM:一旦执行此操作,表数据全部清除(不带WHERE)。同时,数据是可以实现回滚的
      #测试代码,一步一步执行
      CREATE TABLE myemp3
      AS
      SELECT e.employee_id emp_id,e.last_name lname,d.department_name
      FROM employees e JOIN departments d
      ON e.department_id = d.department_id;
      
      SELECT *
      FROM myemp3;
      
      COMMIT;
      
      SET autocommit = FALSE;
      
      DELETE FROM myemp3;
      
      SELECT *
      FROM myemp3;
      
      ROLLBACK;
      
      SELECT *
      FROM myemp3;

(3)DDL和DML的说明

  1. DDL的操作一旦执行,就不能回滚。指令SET autocommit = FALSE对DDL操作失效
  2. DML的操作在默认情况下,一旦执行,也是不可回滚的。但是,如果在执行DML之前,执行了SET autocommit = FALSE,则执行的DML操作就可以实现回滚
  3. 因为在执行完DDL操作之后,一定会执行一次COMMIT,而此COMMIT操作不受SET autocommit = FALSE影响
  4. 阿里开发规范:
    1. TRNCATE TABLE比DELETE FROM速度快,且使用的系统和事务日志资源少,但是TRUNCATE FROM无事务且不触发TRIGGER,有可能造成事故,故不建议在开发代码中使用此语句
    2. 说明:TRNCATE TABLE在功能上与不带WHERE子句的DELETE语句相同

(4)阿里MySQL命名规范

  1. 表名、字段名必须使用小写字母或数字,禁止出现数字开头,禁止两个下划线中间只出现数字。数据库字段名的修改代价很大,因为无法进行预发布,所以字段名称需要慎重考虑
  2. 禁用保留字,如 desc、range、match、delayed 等,请参考 MySQL 官方保留字
  3. 表必备三字段:id, gmt_create, gmt_modified
    1. 其中 id 必为主键,类型为BIGINT UNSIGNED、单表时自增、步长为 1
    2. gmt_create, gmt_modified 的类型均为 DATETIME 类型,前者现在时表示主动式创建,后者过去分词表示被动式更新
  4. 表的命名最好是遵循 “业务名称_表的作用”,例如:alipay_task 、 force_project、 trade_config
  5. 库名与应用名称尽量一致
  6. 合适的字符存储长度,不但节约数据库表空间、节约索引存储,更重要的是提升检索速度

(5)如何理解清空表、删除表等操作需谨慎?

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

(6)MySQL8新特性——DDL的原子化

  1. 在MySQL5.7版本中,用下面的测试代码可以发现(book2不存在),book1被删除了
    CREATE DATABASE mytest;
    
    USE mytest;
    
    CREATE TABLE book1(
    book_id INT,
    book_name VARCHAR(255)
    );
    
    SHOW TABLES;
    
    DROP TABLE book1,book2;
  2. 在MySQL8.0版本中,用上述的测试代码可以发现(book2不存在),book1没有被删除
  3. 在MySQL8.0中,InnoDB表的DDL支持事务完整性,即DDL操作要么成功要么回滚。以上面的代码为例,DROP TABLE book1,book2;是一条DDL语句,即它是一个DDL操作。因为库中不存在book2这张表,所以该语句执行会报错。本来它是先删除了book1,再删除book2。因为book2不存在导致报错,所以它会回滚,把book1恢复回来。这也就是说,要么DDL操作(一整条语句)执行成功,要么DDL操作(一整条语句)执行失败,那它就会回滚

九、课后练习一

  1. 创建数据库test01_office,指明字符集位uft8,并在此数据库下执行下述操作
    CREATE DATABASE IF NOT EXISTS test01_office CHARACTER SET 'utf8';
  2. 创建表dept01
    /*
    字段 类型
    id INT(7)
    NAME VARCHAR(25)
    */
    CREATE TABLE IF NOT EXISTS dept01(
    id INT(7),
    NAME VARCHAR(25)
    );
  3. 将表departments中的数据插入新表dept02中
    CREATE TABLE IF NOT EXISTS dept02
    AS
    SELECT *
    FROM atguigudb.departments;
  4. 创建表emp01
    /*
    字段 类型
    id INT(7)
    first_name VARCHAR (25)
    last_name VARCHAR(25)
    dept_id INT(7)
    */
    CREATE TABLE IF NOT EXISTS emp01(
    id INT(7),
    first_name VARCHAR(25),
    last_name VARCHAR(25),
    dept_id INT(7)
    );
  5. 将列last_name的长度增加到50
    ALTER TABLE emp01
    MODIFY last_name VARCHAR(50);
  6. 根据表employees创建emp02
    CREATE TABLE emp02
    AS 
    SELECT *
    FROM atguigudb.employees;
  7. 删除表emp01
    DROP TABLE IF EXISTS emp01;
  8. 将表emp02重命名为emp01
    RENAME TABLE emp02
    TO emp01;
  9. 在表dept02和emp01中添加新列test_column,并检查所作的操作
    ALTER TABLE dept02
    ADD test_column VARCHAR(10);
    
    ALTER TABLE emp01
    ADD test_column VARCHAR(10);
    
    DESC dept02;
    
    DESC emp01;
  10. 直接删除表emp01中的列 department_id
    ALTER TABLE emp01
    DROP COLUMN department_id;

十、课后练习二

  1. 创建数据库 test02_market
    CREATE DATABASE IF NOT EXISTS test02_market;
  2. 创建数据表 customers
    CREATE TABLE IF NOT EXISTS customers(
    c_num INT,
    c_name VARCHAR(50),
    c_contact VARCHAR(50),
    c_city VARCHAR(50),
    c_birth DATE
    );
  3. 将 c_contact 字段移动到 c_birth 字段后面
     ALTER TABLE customers
     MODIFY c_contact VARCHAR(50) AFTER c_birth;
  4. 将 c_name 字段数据类型改为 varchar(70)
    ALTER TABLE customers
    MODIFY c_name VARCHAR(70);
  5. 将c_contact字段改名为c_phone
    ALTER TABLE customers
    CHANGE c_contact c_phone VARCHAR(50);
  6. 增加c_gender字段到c_name后面,数据类型为char(1)
    ALTER TABLE customers
    ADD c_gender CHAR(1) AFTER c_name;
  7. 将表名改为customers_info
    RENAME TABLE customers
    TO customers_info;
  8. 删除字段c_city
    ALTER TABLE customers_info
    DROP COLUMN c_city;

十一、课后练习三

  1. 创建数据库test03_company
    CREATE DATABASE IF NOT EXISTS test03_company;
  2. 创建表offices
    CREATE TABLE IF NOT EXISTS offices(
    officeCode INT,
    city VARCHAR(30),
    address varchar(50),
    country VARCHAR(50),
    postalCode VARCHAR(25)
    );
  3. 创建表employees
    CREATE TABLE IF NOT EXISTS employees(
    empNum INT,
    lastname VARCHAR(50),
    firstname VARCHAR(50),
    mobile VARCHAR(25),
    `code` INT,
    jobTitle VARCHAR(50),
    birth DATE,
    note VARCHAR(255),
    sex VARCHAR(5)
    );
  4. 将表employees的mobile字段修改到code字段后面
    ALTER TABLE employees
    MODIFY mobile VARCHAR(25) AFTER `code`;
  5. 将表employees的birth字段改名为birthday
    ALTER TABLE employees
    CHANGE birth birthday DATE;
  6. 修改sex字段,数据类型为char(1)
    ALTER TABLE employees
    MODIFY sex CHAR(1);
  7. 删除字段note
    ALTER TABLE employees
    DROP COLUMN note;
  8. 增加字段名favoriate_activity,数据类型为varchar(100)
    ALTER TABLE employees
    ADD favoriate_activity VARCHAR(100);
  9. 将表employees的名称修改为 employees_info
    RENAME TABLE employees
    TO employees_info;

http://www.kler.cn/a/470511.html

相关文章:

  • Mesa llvmpipe和softpipe对比
  • 基于RedHat9部署WordPress+WooCommerce架设购物网站
  • 网页数据如何正确copy到postman中
  • 【C语言程序设计——选择结构程序设计】求阶跃函数的值(头歌实践教学平台习题)【合集】
  • 利用 NineData 实现 PostgreSQL 到 Kafka 的高效数据同步
  • Git 常用命令及其使用场景
  • DINOv2+Qwen2.5-VL-2B+LoRA实现image caption的微调
  • k8s集群部署 - 高版本(1.28.2) docker(运行时)
  • 华为 Sensor 省电策略调研
  • webpack-dev-server.cmd解析
  • 华为设备的VRP系统详解
  • 当算法遇到线性代数(四):奇异值分解(SVD)
  • Docker中运行Qt应用程序——待继续研究
  • docker学习记录:部署es+kibana
  • 香橙派5plus单独编译并安装linux内核无法启动的原因分析与解决记录
  • Microi 吾码与 JavaScript:前端低代码平台的强大组合
  • 成都和力九垠科技有限公司九垠赢系统Common存在任意文件上传漏洞
  • 2024年1月4日蜻蜓hr人才招聘系统v1.1.7更新-正式版发布-客户端源代码开源发布供学习-本产品完成上线正式版-修复多个bug-优雅草果果|小无
  • 2024.1.5总结
  • 小程序租赁系统开发的优势与应用前景分析
  • 如何限制大量请求并发
  • iOS - 引用计数(ARC)
  • 《Python游戏编程入门》注-第9章7
  • EasyExcel数据的导入导出
  • 数据结构与算法-顺序表
  • 使用扣子实现营销获客套电机器人-工作流+多维表格+飞书机器人