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 切库
相关推荐
zhoutongsheng1 小时前
SQL利用子查询实现复杂条件排序_嵌套逻辑实现业务规则
jvm·数据库·python
一直有一个ac的梦想1 小时前
cmu15445 2025fall lec15 query optimiaztion Pt1
java·服务器·数据库
2301_766283441 小时前
如何在 Go 中使用 gocql 执行本地 CQL 脚本文件
jvm·数据库·python
dFObBIMmai1 小时前
MongoDB防注入攻击指南
jvm·数据库·python
彳亍1011 小时前
如何解决Oracle启动ORA-00119错误_网络服务名与listener相关性
jvm·数据库·python
weixin_459753941 小时前
c++怎么编写多线程安全的跨平台文件日志库_无锁队列与异步IO【附源码】
jvm·数据库·python
夏恪1 小时前
如何用 IDBKeyRange 范围匹配检索特定区间的本地数据
jvm·数据库·python
2301_766283441 小时前
如何防止SQL拼接漏洞_使用PDO对象实现安全的SQL交互
jvm·数据库·python
u0110225121 小时前
如何解决Oracle 12c以上版本的ORA-65096_C##公共用户前缀限制
jvm·数据库·python