建库字符集选择`utf8mb4` + `utf8mb4_unicode_ci` 组合

在 MySQL 中创建 UTF-8 编码的数据库时,请直接使用 **`utf8mb4`** 字符集(而非旧版的 `utf8`),这是 MySQL 中真正的 UTF-8 实现。以下是具体操作和注意事项:


一、创建数据库(2种方式)

1. 基础版(自动选择默认校对规则)

```sql

CREATE DATABASE your_database_name

CHARACTER SET utf8mb4

COLLATE utf8mb4_unicode_ci;

```

2. 精简版(MySQL 8.0+ 默认使用 `utf8mb4`)

```sql

CREATE DATABASE your_database_name;

```


二、为什么必须选 `utf8mb4`?

  • ✅ **完全支持 Unicode**:包含 Emoji 表情符号(如 😊)、生僻汉字、特殊符号等(`utf8` 仅支持 3 字节字符,无法存储 4 字节字符)。

  • ✅ **兼容性**:现代 MySQL 版本(5.5.3+)均支持,且是当前标准方案。


三、校对规则选择(`COLLATE`)

  • **`utf8mb4_unicode_ci`**:基于 Unicode 标准排序,准确性高(推荐)。

  • **`utf8mb4_general_ci`**:旧式简单排序,速度快但准确性略低(已逐渐淘汰)。


四、后续使用注意事项

  1. **创建表时显式指定字符集**(避免继承服务器默认配置):

```sql

CREATE TABLE your_table (

id INT PRIMARY KEY,

content VARCHAR(255)

) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

```

  1. **连接字符串配置**(确保应用层与数据库编码一致):
  • JDBC 示例:`jdbc:mysql://host/db?useUnicode=true&characterEncoding=UTF-8`

  • 其他语言同理,需明确指定 UTF-8 编码。


五、验证设置是否生效

```sql

-- 查看数据库编码

SELECT SCHEMA_NAME, DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME

FROM INFORMATION_SCHEMA.SCHEMATA

WHERE SCHEMA_NAME = 'your_database_name';

-- 查看表编码

SHOW CREATE TABLE your_table;

```


**总结**:直接使用 `utf8mb4` + `utf8mb4_unicode_ci` 组合,确保全面兼容 Unicode 并避免未来编码问题。

相关推荐
毕设源码-邱学长1 分钟前
【开题答辩全过程】以 智能商品数据分析系统为例,包含答辩的问题和答案
java·eclipse
Kira Skyler11 分钟前
抓虫:sw架构防火墙服务启动失败 Unable to initialize Netlink socket: 不支持的协议
java·linux
张较瘦_3 小时前
[论文阅读] 软件工程 | 告别“线程安全玄学”:基于JMM的Java类静态分析,CodeQL3分钟扫遍GitHub千仓错误
java·论文阅读·安全
A尘埃5 小时前
智慧零售全渠道业务中台系统
java·零售
小wanga8 小时前
C++知识
java·开发语言·c++
我是渣哥9 小时前
Java String vs StringBuilder vs StringBuffer:一个性能优化的探险故事
java·开发语言·jvm·后端·算法·职场和发展·性能优化
工一木子9 小时前
深入Java并发:锁机制原理剖析与性能优化实战
java·性能优化·并发·
你我约定有三9 小时前
java--写在 try 中的创建连接
java·开发语言
ERP老兵-冷溪虎山9 小时前
Python/JS/Go/Java同步学习(第三篇)四语言“切片“对照表: 财务“小南“纸切片术切凭证到崩溃(附源码/截图/参数表/避坑指南/老板沉默术)
java·javascript·python·golang·中医编程·四语言同步学习·职场生存指南