【MySQL进阶之路 | 基础篇】表的创建与操作表

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 【MySQL进阶之路 | 基础篇】表的创建与操作表

1. 创建表

创建表有两种方式 : 一种是白手起家自己添,一种是富二代直接继承.

2. 创建方式1

(1). 必须具备条件

  • CREATE TABLE权限
  • 存储空间

(2). 语法格式

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

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

(3). 必须指定

  • 表名
  • 列名(字段名),数据类型,长度(如字符串类型的长度)

(4). 可选指定

  • 约束条件
  • 默认值

(5). 例

CREATE TABLE IF NOT EXISTS mytable(
      mytable_id INT(10),
      mytable_name VARCHAR(20),
      mytable_salary DOUBLE(8, 2)
);
SHOW TABLES;

  • MySQL在执行表语句时,将id字段设置为INT(11). 11指int类型指定的显示宽度.默认的显示宽度为11.
  • salary字段设置为DOUBLE(8,2),指一共占8个字符宽度,小数点后占2位.
  • name字段设置为VARCHAR(20),字符串类型,且字符串最长长度为20.

3. 创建方式2

使用AS subquery选项,将创建表和插入数据结合起来.

例 :

  • 指定的列和子查询中的列一一对应.
  • 通过列名和默认值定义列.

4. 查看数据表的结构

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


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

可以知道,表mytable3使用的字符编码集是utf8mb3.即该表所在的数据库使用的默认字符编码集为utf8mb3.

5. 修改表

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

使用ALTER TABLE语句可实现

  • 向已有的表中添加列.
  • 修改现有表的列.
  • 删除现有表的列.
  • 重命名现有表的列.

(1). 追加一个列.

可选关键字FIRST,使添加的字段在第一个字段位置.

可选字段AFTER,使添加的字段在某某字段之后.

默认情况下是添加到表的字段的最后一个位置.

(2). 修改一个列

  • 可以修改列的数据类型,长度,默认值和位置.
  • 对默认值的修改只影响今后对表的修改.
  • 此外,还可以通过此种方式修改表的约束.

格式 :

ALTER TABLE 表名 MODIFY 【COLUMN】 字段名1 字段类型 【DEFAULT 默认值】【FIRST|AFTER 字段名2】;

例 :

(3). 重命名一个列

格式 :

ALTER TABLE 表名 CHANGE 【column】 列名 新列名 新数据类型;

例 :

注 :

  • 修改表的字段名时,必须指明要替换字段的类型.如该例的VARCHAR(20).否则会报错.

(4). 删除一个列

格式 :

ALTER TABLE 表名 DROP 【COLUMN】字段名

例 :

6. 重命名表

(1). 方式1 : 使用RENAME

例 :

(2). 方式2 : ALTER

7. 删除表

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

例 :

注 :

  • DROP TABLE语句执行完就不能回滚.即这个表真正意义上被删除了.

8. 清空表

(1). TRUNCATE TABLE语句

  • 删除表中所有数据.但并不删除表的结构.
  • 释放表的存储空间.
  • 执行后不能回滚.
TRUNCATE TABLE mytable1;

(2). DELECT FROM语句

  • 删除表中所有数据.但并不删除表的结构.
  • 执行后可以回滚.
DELETE FROM mytable1;

注 :

  • TRUNCATE TABLE比DELETE FROM速度快,且使用的系统和事务少,但TRUNCATE无事务且不触发TRIGGER,有可能造成事故.故不建议使用TRUNCATE TABLE语句.
  • TRUNCATE TABLE语句在功能上与不带WHERE子句的DELECT语句相同.
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
安全 关系型数据库 MySQL
【MySQL】表的增删查改
【MySQL】表的增删查改
|
5天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(2)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
5天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(1)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
6天前
|
分布式计算 DataWorks MaxCompute
DataWorks产品使用合集之需要将mysql 表(有longtext类型字段) 迁移到odps,但odps好像没有对应的类型支持,该怎么办
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
11天前
|
SQL 关系型数据库 MySQL
mysql sql语句删除一个库下的所有表
mysql sql语句删除一个库下的所有表
|
2天前
|
存储 SQL 关系型数据库
【MySQL技术内幕】4.1-索引组织表
【MySQL技术内幕】4.1-索引组织表
6 0
|
5天前
|
存储 关系型数据库 MySQL
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(4)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
5天前
|
存储 SQL 关系型数据库
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】(3)
MySQL 进阶使用【函数、索引、视图、存储过程、存储函数、触发器】
|
6天前
|
分布式计算 DataWorks MaxCompute
DataWorks产品使用合集之新创建的工作空间,任务提交了,但是周期实例里面没任何数据,是什么导致的
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
9天前
|
SQL 存储 关系型数据库
MySQL数据库——SQL(1)-SQL通用语法、SQL分类、DDL(数据库操作、表操作)
MySQL数据库——SQL(1)-SQL通用语法、SQL分类、DDL(数据库操作、表操作)
17 1

推荐镜像

更多