MySQL入门指南:数据库的创建、管理与字符集详解
在MySQL的学习中,对数据库(Database)本身的操作是第一步,也是最基础且关键的一步。本文将系统性地介绍如何创建、查看、修改、删除数据库,并深入讲解字符集与校验规则的影响。
一、创建数据库
创建数据库的基础语法如下:
CREATE DATABASE [IF NOT EXISTS] db_name [character_options];
关键字说明:
-
CREATE DATABASE: 核心命令。 -
IF NOT EXISTS: 可选项。如果指定,当数据库已存在时不会报错,只会产生一个警告。这是一个良好的习惯,可以避免脚本因重复创建而中断。 -
character_options: 用于指定数据库的字符集和校验规则。
创建实例:
-
创建最简单的数据库
系统会使用默认的字符集(通常为utf8)和校验规则(通常为utf8_general_ci)。
CREATE DATABASE db1; -
创建指定字符集的数据库
CREATE DATABASE db2 CHARACTER SET utf8; -- 或简写为 CREATE DATABASE db2 CHARSET=utf8; -
创建指定字符集和校验规则的数据库
CREATE DATABASE db3 CHARSET=utf8 COLLATE utf8_general_ci;
二、字符集与校验规则:为什么它们很重要?
字符集(Character Set)决定了数据库能存储哪些字符(如中文、英文);校验规则(Collation)则决定了字符比较和排序的规则,其核心影响在于是否区分大小写。
1. 查看相关设置
-
查看系统默认字符集和校验规则:
SHOW VARIABLES LIKE 'character_set_database'; SHOW VARIABLES LIKE 'collation_database'; -
查看MySQL支持的所有字符集:
SHOW CHARSET; -
查看MySQL支持的所有校验规则:
SHOW COLLATION;
2. 校验规则的实际影响
让我们通过一个实验来直观感受校验规则的重要性。
-
场景一:不区分大小写(utf8_general_ci)
-- 创建数据库和表 CREATE DATABASE test1 COLLATE utf8_general_ci; USE test1; CREATE TABLE person (name VARCHAR(20)); -- 插入数据 INSERT INTO person VALUES ('a'), ('A'), ('b'), ('B'); -- 查询 name='a' SELECT * FROM person WHERE name='a';查询结果 :会返回两条记录
a和A。因为utf8_general_ci规则认为a和A是等价的。 -
场景二:区分大小写(utf8_bin)
-- 创建数据库和表 CREATE DATABASE test2 COLLATE utf8_bin; USE test2; CREATE TABLE person (name VARCHAR(20)); -- 插入相同数据 INSERT INTO person VALUES ('a'), ('A'), ('b'), ('B'); -- 查询 name='a' SELECT * FROM person WHERE name='a';查询结果 :只会返回一条记录
a。因为utf8_bin规则通过二进制值来比较,严格区分大小写。 -
对排序的影响
分别在不同的数据库中对
name字段进行排序:-- 在 test1 (不区分大小写) 中排序 USE test1; SELECT * FROM person ORDER BY name; -- 结果可能为:a, A, b, B (同类字母大小写顺序可能不稳定) -- 在 test2 (区分大小写) 中排序 USE test2; SELECT * FROM person ORDER BY name; -- 结果会严格按照ASCII码排序:A, B, a, b
结论 :在创建数据库时,根据业务需求选择合适的字符集和校验规则至关重要。例如,如果要求用户名唯一且不区分大小写(如 'Alice' 和 'alice' 被视为同一用户),就应使用 ci(Case Insensitive) 规则的校验规则。
三、数据库的日常管理操作
1. 查看数据库
列出当前MySQL服务器中的所有数据库。
SHOW DATABASES;
2. 显示数据库的创建语句
用于查看创建某个数据库时的完整SQL语句,非常实用。
SHOW CREATE DATABASE mytest;
3. 修改数据库
修改操作主要是针对数据库的字符集和校验规则。
ALTER DATABASE mytest CHARSET=gbk COLLATE gbk_chinese_ci;
4. 删除数据库(谨慎操作!)
删除数据库会同时删除数据库内的所有表和数据,且不可恢复,请务必谨慎!
DROP DATABASE [IF EXISTS] db_name;
强烈建议始终使用 IF EXISTS,以防止删除不存在的数据库时出现错误。
四、数据库的备份与恢复
1. 备份(Backup)
使用 mysqldump工具在命令行(非MySQL客户端)进行备份。-B选项表示备份整个数据库。
# 语法
mysqldump -P端口 -u用户名 -p密码 -B 数据库名 > 备份文件路径.sql
# 示例:将mytest数据库备份到D盘
mysqldump -P3306 -uroot -p123456 -B mytest > D:/mytest.sql
-
备份单张表 :
mysqldump -u root -p 数据库名 表名1 表名2 > 路径.sql -
备份多个数据库 :
mysqldump -u root -p -B 数据库名1 数据库名2 > 路径.sql
2. 恢复(Restore)
在MySQL客户端中,使用 source命令执行备份的SQL文件。
-- 首先需要连接到MySQL
mysql -uroot -p
-- 然后执行恢复(如果备份时用了-B,会自动创建数据库)
SOURCE D:/mytest.sql;
五、查看连接情况
当发现数据库响应缓慢时,可以查看当前有哪些用户或程序连接到了数据库。
SHOW PROCESSLIST;
这个命令可以帮助你排查异常连接,是数据库安全性和性能调优的一个基础工具。
总结
掌握对数据库本身的操作是管理MySQL的基石。从创建时考虑字符集,到日常的维护、备份,每一步都关系到数据的完整性和安全性。理解校验规则对查询和排序的深层影响,更能让你在开发中避免很多隐蔽的坑。