在MySQL中,字符集用于确定数据库中存储的字符的编码方式。MySQL提供了多种字符集供选择,以支持不同语言的字符存储。
- 查看当前MySQL支持的所有字符集:
SHOW CHARACTER SET;
- 查看某个字符集的详细信息:
SHOW CHARACTER SET LIKE 'utf8';
设置数据库字符集:
在创建数据库时,可以指定默认字符集和排序规则:
CREATE DATABASE mydb CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
设置表字符集:
在创建表时,可以指定字符集和排序规则:
CREATE TABLE mytable (
id INT PRIMARY KEY,
text VARCHAR(255)
) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
设置列字符集:
在创建列时,可以指定字符集和排序规则:
CREATE TABLE mytable (
id INT PRIMARY KEY,
text VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci
);
查看字符集和排序规则设置:
可以通过以下SQL查询当前数据库、表或列的字符集和排序规则:
-- 当前数据库
SELECT DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME FROM information_schema.SCHEMATA WHERE SCHEMA_NAME = 'mydb';
-- 当前表
SELECT TABLE_SCHEMA, TABLE_NAME, DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = 'mydb' AND TABLE_NAME = 'mytable';
-- 当前列
SELECT TABLE_SCHEMA, TABLE_NAME, COLUMN_NAME, CHARACTER_SET_NAME, COLLATION_NAME FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = 'mydb' AND TABLE_NAME = 'mytable' AND COLUMN_NAME = 'text';
修改字符集和排序规则:
如果需要修改现有数据库、表或列的字符集和排序规则,可以使用以下语句:
-- 修改数据库字符集
ALTER DATABASE mydb CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
-- 修改表字符集
ALTER TABLE mytable CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
-- 修改列字符集
ALTER TABLE mytable MODIFY text VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
配置文件设置字符集:
在my.cnf
或my.ini
配置文件中,可以设置默认的字符集和排序规则:
[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
连接字符集设置:
在连接MySQL时,可以指定字符集:
mysql -u username -p --default-character-set=utf8mb4
以上是配置MySQL字符集的基本方法,确保在数据库操作中正确设置字符集,以避免字符编码问题。