MySql教程

mysql之建表collaction和数据库collaction不一致问题

本文主要是介绍mysql之建表collaction和数据库collaction不一致问题,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

问题说明:

DB设置

建表语句

DROP TABLE IF EXISTS TEST_TABLE;
CREATE TABLE IF NOT EXISTS TEST_TABLE (
...
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='TEST';

结果

表建好之后,字符集是utf8mb4,排序集是默认的utf8mb4_0900_ai_ci,而不是mysql服务器设置的utf8mb4_general_ci

原因

只设置了字符集,没有设置排序集

解决方案

方式一:建表时不设置字符集,则字符集直接继承DB

方式二:建表时,同时设置字符集和排序级别

官方文档

https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_default_collation_for_utf8mb4

这篇关于mysql之建表collaction和数据库collaction不一致问题的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!