MySQL DDL(数据定义语言)总结

DDL:

text 复制代码
Data Definition Language
数据定义语言

作用:

用于定义和管理数据库对象。

包括:

  • 数据库
  • 字段
  • 约束

核心思想:

text 复制代码
DDL 负责"结构"
DML 负责"数据"

数据库操作


查询数据库

查询所有数据库

sql 复制代码
SHOW DATABASES;

查看当前 MySQL 中所有数据库。


查询当前使用的数据库

sql 复制代码
SELECT DATABASE();

查看当前正在操作哪个数据库。


创建数据库

sql 复制代码
CREATE DATABASE [IF NOT EXISTS] 数据库名
[DEFAULT CHARSET 字符集]
[COLLATE 排序规则];

示例:

sql 复制代码
CREATE DATABASE IF NOT EXISTS school
DEFAULT CHARSET utf8mb4;

关键点

IF NOT EXISTS

如果数据库不存在才创建。

存在则不报错。


DEFAULT CHARSET

指定字符集。

常用:

text 复制代码
utf8mb4

支持:

  • 中文
  • emoji
  • 特殊字符

COLLATE

指定排序规则。

一般很少手动写。


删除数据库

sql 复制代码
DROP DATABASE [IF EXISTS] 数据库名;

示例:

sql 复制代码
DROP DATABASE IF EXISTS school;

使用数据库

sql 复制代码
USE 数据库名;

示例:

sql 复制代码
USE school;

表示:

后续操作都在这个数据库中进行。


表操作


查询表

查询当前数据库所有表

sql 复制代码
SHOW TABLES;

查询表结构

sql 复制代码
DESC 表名;

示例:

sql 复制代码
DESC student;

查看:

  • 字段名
  • 类型
  • 是否为空
  • 主键
  • 默认值

查询建表语句

sql 复制代码
SHOW CREATE TABLE 表名;

示例:

sql 复制代码
SHOW CREATE TABLE student;

作用:

查看当初创建表时的完整 SQL。

非常重要。


创建表

语法:

sql 复制代码
CREATE TABLE 表名(
    字段1 类型 [COMMENT 注释],
    字段2 类型 [COMMENT 注释],
    字段3 类型 [COMMENT 注释]
)[COMMENT 表注释];

示例:

sql 复制代码
CREATE TABLE student(
    id INT COMMENT '编号',
    name VARCHAR(20) COMMENT '姓名',
    age INT COMMENT '年龄'
) COMMENT '学生表';

修改表


添加字段

sql 复制代码
ALTER TABLE 表名
ADD 字段名 类型(长度)
[COMMENT 注释]
[约束];

示例:

sql 复制代码
ALTER TABLE student
ADD gender CHAR(1) COMMENT '性别';

修改字段类型

sql 复制代码
ALTER TABLE 表名
MODIFY 字段名 新类型(长度);

示例:

sql 复制代码
ALTER TABLE student
MODIFY name VARCHAR(50);

作用:

修改字段数据类型。


修改字段名

sql 复制代码
ALTER TABLE 表名
CHANGE 旧字段名 新字段名 类型(长度)
[COMMENT 注释]
[约束];

示例:

sql 复制代码
ALTER TABLE student
CHANGE name username VARCHAR(30);

作用:

  • 修改字段名
  • 修改字段类型

一起完成。


修改表名

sql 复制代码
ALTER TABLE 旧表名
RENAME TO 新表名;

示例:

sql 复制代码
ALTER TABLE student
RENAME TO student_info;

删除表

sql 复制代码
DROP TABLE [IF EXISTS] 表名;

示例:

sql 复制代码
DROP TABLE IF EXISTS student;

清空表

sql 复制代码
TRUNCATE TABLE 表名;

示例:

sql 复制代码
TRUNCATE TABLE student;

作用:

删除所有数据。

特点:

  • 保留表结构
  • 相当于重新创建表
  • 执行速度快

删除字段

sql 复制代码
ALTER TABLE 表名
DROP 字段名;

示例:

sql 复制代码
ALTER TABLE student
DROP age;

DDL 最核心理解

DDL 操作的是:

text 复制代码
数据库结构

不是数据本身。

比如:

  • 创建数据库
  • 创建表
  • 修改字段
  • 删除字段

这些都属于:

text 复制代码
定义结构

高频面试点


DROP、DELETE、TRUNCATE 区别

DROP

直接删除整个对象。

text 复制代码
表没了
结构也没了
数据也没了

DELETE

删除数据。

text 复制代码
表还在
结构还在

可以加 WHERE。


TRUNCATE

清空整张表。

text 复制代码
表还在
结构还在
数据全没

执行速度比 DELETE 快。


最后总结

操作 语句
查询数据库 SHOW DATABASES
创建数据库 CREATE DATABASE
删除数据库 DROP DATABASE
使用数据库 USE
查询表 SHOW TABLES
查看表结构 DESC
查看建表语句 SHOW CREATE TABLE
创建表 CREATE TABLE
添加字段 ALTER TABLE ADD
修改字段 ALTER TABLE MODIFY
修改字段名 ALTER TABLE CHANGE
删除字段 ALTER TABLE DROP
删除表 DROP TABLE
清空表 TRUNCATE TABLE

记忆口诀

text 复制代码
CREATE 创建
ALTER 修改
DROP 删除
TRUNCATE 清空
DESC 看结构
SHOW 看信息
USE 切库
相关推荐
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐1 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence1 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
云技纵横1 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神1 天前
三、用户与权限管理
数据库·mysql
摇滚侠2 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
麦聪聊数据2 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
ApacheSeaTunnel2 天前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
shushangyun_2 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化