我有一个MySql 5.6数据库,其中数据库使用utf8_unicode_ci的排序规则。每次创建新表时,表都是用utf8_unicode_ci创建的,但是varchar列是用utf8_general_ci设置的。
当我查看变量时,我看到以下内容
'collation_connection', 'utf8_general_ci'
'collation_database', 'utf8_unicode_ci'
我可以手动执行,SET collation_connection = utf8_unicode_ci;
,然后创建我的表,一切都可以按照我的意愿工作。
问题是,默认情况下如何设置collation_connection?我尝试过使用下面的文章通过my.cnf进行设置,但我似乎无法获得与更改的连接。想法?
发布于 2022-06-14 11:41:25
您可以通过在“由服务器为每个连接的客户端执行的字符串”配置文件的[mysqld]
部分中包括这一行来配置my.cnf:
[mysqld]
init_connect='SET collation_connection = utf8mb4_unicode_ci;'
也许最好使用SET NAMES
(details 这里):
[mysqld]
init_connect='SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci;'
若要设置新表的默认字符集和排序规则,请指定:
[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
参考手册解释道:
如果在CREATE语句中未指定数据库字符集和排序规则,则使用服务器字符集和排序规则作为默认值。他们没有别的目的。
考虑使用utf8mb4
而不是utf8
。参考这里。
https://stackoverflow.com/questions/35344625
复制相似问题