MySQL 进阶:库与表的DDL核心操作全指南(含实战案例)

MySQL 进阶:库与表的DDL核心操作全指南(含实战案例)
在这里插入图片描述

🔥草莓熊Lotso:个人主页
❄️个人专栏: 《C++知识分享》《Linux 入门到实践:零基础也能懂》
✨生活是默默的坚持,毅力是永久的享受!


🎬 博主简介:

在这里插入图片描述

文章目录


前言:

在上一篇 MySQL 基础入门中,我们了解了数据库的基本概念和简单操作。而在实际开发中,数据库和表的创建、修改、备份、删除等操作是日常高频需求,掌握这些精准操作能避免数据丢失、提升开发效率。本文将基于 MySQL 实战场景,详细拆解库与表的完整操作流程,包括字符集选择、表结构设计、备份恢复等核心知识点,带你从 “会用” 进阶到 “活用” MySQL。

一. 数据库(库)的核心操作

数据库是表的容器,合理的库操作是数据管理的基础。下面涵盖库的创建、查询、修改、删除、备份恢复等关键操作,同时详解字符集和校验规则的影响。

1.1 创建数据库:指定字符集与校验规则

创建数据库时,不仅要定义库名,还需根据业务场景指定字符集(如支持中文的utf8)和校验规则(如是否区分大小写),避免后续出现乱码或查询异常。

1.1.1 语法格式

CREATEDATABASE[IFNOTEXISTS] db_name [DEFAULT]CHARACTERSET charset_name [DEFAULT]COLLATE collation_name;
  • IF NOT EXISTS:避免重复创建数据库报错(可以不加但是这里推荐加);
  • CHARACTER SET:指定数据库字符集(默认utf8);
  • COLLATE:指定字符集的校验规则(默认utf8_general_ci)。

1.1.2 实战案例

-- 1. 创建默认字符集的数据库db1CREATEDATABASEIFNOTEXISTS db1;-- 2. 创建指定utf8字符集的数据库db2CREATEDATABASEIFNOTEXISTS db2 CHARACTERSET utf8;-- 3. 创建指定字符集和校验规则的数据库db3CREATEDATABASEIFNOTEXISTS db3 CHARACTERSET utf8 COLLATE utf8_general_ci;

1.2 字符集与校验规则:影响查询和排序

字符集决定了数据的存储编码(如是否支持中文),校验规则则影响字符串的比较和排序(如是否区分大小写),这是容易被忽略但关键的细节。

1.2.1 查看系统默认配置

-- 查看默认字符集show variables like'character_set_database';-- 查看默认校验规则show variables like'collation_database';
在这里插入图片描述

1.2.2 查看支持的字符集和校验规则

-- 查看所有支持的字符集showcharset;-- 查看所有支持的校验规则show collation;

1.2.3 校验规则的实际影响

以 “是否区分大小写” 为例,对比两种常用校验规则:

  • utf8_general_ci:不区分大小写(ci=case insensitive);
  • utf8_bin:区分大小写(bin=binary,按二进制比较)。

案例演示

-- 1. 创建不区分大小写的数据库test1CREATEDATABASE test1 COLLATE utf8_general_ci;USE test1;CREATETABLE person(name varchar(20));INSERTINTO person VALUES('a'),('A'),('b'),('B');-- 查询name='a':返回'a'和'A'(不区分大小写)SELECT*FROM person WHERE name='a';-- 排序:按字母顺序排序(不区分大小写)SELECT*FROM person ORDERBY name;
在这里插入图片描述
-- 2. 创建区分大小写的数据库test2CREATEDATABASE test2 COLLATE utf8_bin;USE test2;CREATETABLE person(name varchar(20));INSERTINTO person VALUES('a'),('A'),('b'),('B');-- 查询name='a':仅返回'a'(区分大小写)SELECT*FROM person WHERE name='a';-- 排序:按二进制ASCII码排序(大写在前,小写在后)SELECT*FROM person ORDERBY name;
在这里插入图片描述

1.3 操纵数据库:查询、修改、删除

1.3.1 查看所有数据库

showdatabases;

1.3.2 查看数据库创建语句

验证数据库的字符集、校验规则等配置:

showcreatedatabase db3;

输出样例

+----------+----------------------------------------------------------------+ | Database | Create Database | +----------+----------------------------------------------------------------+ | db3 | CREATE DATABASE `db3` /*!40100 DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci */ | +----------+----------------------------------------------------------------+ 
  • 反引号 `:防止库名与关键字冲突;

/*!40100 ... */:条件执行,MySQL 版本≥4.0.10 时生效。

在这里插入图片描述

1.3.3 修改数据库(仅字符集和校验规则)

数据库创建后,仅支持修改字符集和校验规则,不支持修改库名(需通过备份恢复间接修改):

-- 将db3的字符集改为gbkALTERDATABASE db3 CHARACTERSET gbk;

1.3.4 删除数据库(谨慎操作!)

删除数据库会级联删除所有表和数据,且无法恢复:

DROPDATABASEIFEXISTS db3;

1.4 数据库备份与恢复:避免数据丢失

备份恢复是数据库运维的核心技能,支持全库备份、单表备份、多库备份。

1.4.1 备份(退出 MySQL 客户端执行)

  • 语法
mysqldump -P端口 -u用户名 -p密码 -B 数据库名 > 备份文件路径 
  • 补充说明
    • 备份单表:mysqldump -uroot -p 数据库名 表名1 表名2 > 备份文件路径
    • 备份多库:mysqldump -uroot -p -B 数据库名1 数据库名2 ... > 备份文件路径

1.4.2 恢复(在 MySQL 客户端执行)

-- 恢复整个数据库 source 备份文件路径;

注意:若备份时未加-B参数,恢复前需先创建空数据库并切换:

CREATEDATABASEIFNOTEXISTS mytest;USE mytest; source 备份文件路径;

1.5 查看数据库连接:排查并发问题

当数据库响应缓慢时,可查看当前连接情况,排查异常连接(如被入侵):

show processlist;

输出样例

+----+------+-----------+------+---------+------+-------+------------------+ | Id | User | Host | db | Command | Time | State | Info | +----+------+-----------+------+---------+------+-------+------------------+ |2| root | localhost | test1| Sleep |120|| NULL ||3| root | localhost | NULL | Query |0| NULL | show processlist | +----+------+-----------+------+---------+------+-------+------------------+ 
  • Command:连接状态(Sleep为空闲,Query为执行中);
  • Time:连接持续时间(秒);
  • Info:执行的 SQL 语句。
在这里插入图片描述

二. 数据表(表)的核心操作

表是存储数据的核心载体,表结构的设计和修改直接影响业务开发,下面涵盖表的创建、查看、修改、删除全流程。

2.1 创建表:指定字段、类型、存储引擎

创建表时需明确字段名、数据类型、字符集、存储引擎等,同时可通过comment添加字段说明。

2.1.1 语法格式

CREATETABLE table_name ( field1 datatype [comment'字段说明'], field2 datatype [comment'字段说明'],...)CHARACTERSET 字符集 COLLATE 校验规则 ENGINE 存储引擎;

2.1.2 实战案例

USE mytest;CREATETABLE users ( id intcomment'用户ID', name varchar(20)comment'用户名', password char(32)comment'密码是32位的MD5加密值', birthday datecomment'生日')CHARACTERSET utf8 ENGINE MyISAM;
在这里插入图片描述

2.1.3 不同存储引擎的文件差异

MySQL 支持插件式存储引擎,不同引擎的表文件存储格式不同:

  • MyISAM(示例中使用):
    • users.frm:表结构文件;
    • users.MYD:表数据文件;
    • users.MYI:表索引文件;
  • InnoDB(默认引擎):
    • users.frm:表结构文件;
    • users.ibd:表数据 + 索引文件(聚簇索引结构)。

2.2 查看表结构:验证表设计

-- 简洁查看表结构desc users;-- 详细查看表结构(含注释)showcreatetable users;
在这里插入图片描述


在这里插入图片描述

2.3 修改表:适配业务需求变更

项目开发中,表结构需频繁适配业务变更(如添加字段、修改字段类型等),ALTER TABLE是核心指令。

2.3.1 常用修改操作语法

操作类型语法示例
添加字段ALTER TABLE表名ADD字段名类型 [comment ‘说明’] [AFTER已有字段名]
修改字段类型ALTER TABLE表名MODIFY字段名新类型
修改字段名 + 类型ALTER TABLE表名CHANGE旧字段名新字段名新类型
删除字段ALTER TABLE表名DROP字段名
修改表名ALTER TABLE旧表名RENAME TO新表名(TO可省略)

2.3.2 实战案例

USE mytest;-- 1. 给users表添加字段assets(图片路径),放在birthday之后ALTERTABLE users ADD assets varchar(100)comment'图片路径'AFTER birthday;-- 2. 修改name字段长度为60(适配更长的用户名)ALTERTABLE users MODIFY name varchar(60);-- 3. 删除password字段(假设密码存储方式变更)ALTERTABLE users DROP password;-- 4. 修改表名为employeeALTERTABLE users RENAME employee;-- 5. 将name字段改为xingming(适配中文命名习惯)ALTERTABLE employee CHANGE name xingming varchar(60);

2.3.3 注意事项

  • 添加字段:新字段默认允许为NULL,不会影响原有数据;
  • 修改字段类型:若字段已有数据,需确保新类型兼容旧数据(如varcharint可能失败);
  • 删除字段:字段及对应数据会永久删除,需提前备份。

2.4 删除表(谨慎操作!)

删除表会删除表结构和所有数据,无法恢复:

DROPTABLEIFEXISTS employee;

TEMPORARY:仅删除临时表(CREATE TEMPORARY TABLE创建的表):

DROPTEMPORARYTABLEIFEXISTS temp_table;

三. 总结与避坑指南

本文覆盖了 MySQL 库与表的全流程操作,核心要点总结如下:

  • 创建数据库时,建议明确指定CHARACTER SET utf8和校验规则,避免乱码(也可以提前去自己配置好);
  • 校验规则决定字符串比较逻辑,需根据业务场景选择(如用户名是否区分大小写);
  • 备份恢复是数据安全的保障,重要数据库需定期备份,备份时建议添加-B参数;
  • 修改表结构时,删除字段和修改字段类型需格外谨慎,避免数据丢失;
  • 存储引擎选择:InnoDB 支持事务和行级锁(默认推荐),MyISAM 查询速度快(适合只读场景)。

常见避坑点

  • 库名、表名、字段名避免使用 MySQL 关键字(如orderuser),若必须使用需加反引号 `;
  • 备份时未加-B参数,恢复前需手动创建数据库并切换;
  • 数据库不支持直接修改库名,需通过 “备份→删除旧库→恢复为新库名” 实现;
  • 字段类型选择需合理(如密码用char(32)存储 MD5 值,生日用date类型),避免浪费空间或存储异常,关于类型问题我们后面还会进行更加详细的学习。

结尾:

🍓 我是草莓熊 Lotso!若这篇技术干货帮你打通了学习中的卡点: 👀 【关注】跟我一起深耕技术领域,从基础到进阶,见证每一次成长 ❤️ 【点赞】让优质内容被更多人看见,让知识传递更有力量 ⭐ 【收藏】把核心知识点、实战技巧存好,需要时直接查、随时用 💬 【评论】分享你的经验或疑问(比如曾踩过的技术坑?),一起交流避坑 🗳️ 【投票】用你的选择助力社区内容方向,告诉大家哪个技术点最该重点拆解 技术之路难免有困惑,但同行的人会让前进更有方向~愿我们都能在自己专注的领域里,一步步靠近心中的技术目标! 

结语:掌握库与表的操作是 MySQL 开发的基础,下一篇将深入讲解 MySQL 数据类型、约束(主键、外键、唯一索引)等进阶知识点。创作不易,觉得有帮助的话,欢迎点赞、收藏、关注三连~ 若有操作疑问或场景需求,欢迎在评论区留言交流!

✨把这些内容吃透超牛的!放松下吧✨ʕ˘ᴥ˘ʔづきらど

Read more

Mars-Admin 基于Spring Boot 3 + Vue 3 + UniApp的企业级管理系统

Mars-Admin 基于Spring Boot 3 + Vue 3 + UniApp的企业级管理系统

Mars-Admin 企业级管理系统 🔥 开箱即用的企业级全栈管理系统 🔥 一套基于 Spring Boot 3 + Vue 3 + UniApp 的现代化企业管理平台,采用前后端分离架构,提供完整的权限管理、用户管理、移动端支持等功能,是中小企业快速开发的理想选择。 🌐 在线预览 | 📱 移动端预览 | 📖 API文档 | 📚 使用文档 体验账号: admin | 密码: 123456 ✨ 项目特色 * 🎯 全栈解决方案:后端API + Web管理端 + 移动端小程序,三端统一 * 🚀 技术前沿:基于Spring Boot 3 + Vue 3 + UniApp最新技术栈 * 🎨 现代化UI:Web端基于Ant Design Vue 4,移动端采用毛玻璃设计风格 * 🔐 安全可靠:Sa-Token权限认证,Redis会话管理,完善的RBAC权限模型 * 📊 SQL监控:彩色SQL日志,性能监控,

By Ne0inhk
你真的会打印日志吗?基于 Spring Boot 的全方位日志指南

你真的会打印日志吗?基于 Spring Boot 的全方位日志指南

—JavaEE专栏— 目录 * 一、日志概述:为什么它比 System.out.println 更重要? * 1.1 日志的核心用途 * 1.2 为什么弃用标准输出? * 二、日志框架体系:门面模式的深度解析 * 2.1 门面模式 (Facade Pattern) * 2.2 常见框架对比 * 三、实战:Spring Boot 日志的基本使用 * 3.1 传统方式获取日志对象 * 3.2 进阶方式:使用 Lombok (@Slf4j) * 四、深入理解日志级别 * 五、日志的高级配置 (application.yml) * 5.1 修改日志级别 * 5.

By Ne0inhk
山东大学《Web数据管理》期末复习宝典【万字解析!】

山东大学《Web数据管理》期末复习宝典【万字解析!】

🌈 个人主页:十二月的猫-ZEEKLOG博客 🔥 系列专栏:🏀山东大学期末速通专用_十二月的猫的博客-ZEEKLOG博客 💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光  目录 1. 第二章 网络爬虫 1.1 爬虫基础知识 1.2 爬虫分类 1.3 开源工具 Nutch 2. 第三章 网页分析 2.1 正则表达式 2.2 DOM模型 2.3 Beautiful Soup工具 2.4 Scrapy框架 2.5 不同爬虫工具比较 2.6 元搜索引擎 3. 第四章 爬虫与网站的博弈 3.1 Robot协议 3.

By Ne0inhk