首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySql设置默认值“collation_connection”

MySql设置默认值“collation_connection”
EN

Stack Overflow用户
提问于 2016-02-11 16:21:33
回答 1查看 3.3K关注 0票数 3

我有一个MySql 5.6数据库,其中数据库使用utf8_unicode_ci的排序规则。每次创建新表时,表都是用utf8_unicode_ci创建的,但是varchar列是用utf8_general_ci设置的。

当我查看变量时,我看到以下内容

代码语言:javascript
运行
复制
'collation_connection', 'utf8_general_ci'
'collation_database', 'utf8_unicode_ci'

我可以手动执行,SET collation_connection = utf8_unicode_ci;,然后创建我的表,一切都可以按照我的意愿工作。

问题是,默认情况下如何设置collation_connection?我尝试过使用下面的文章通过my.cnf进行设置,但我似乎无法获得与更改的连接。想法?

将MySQL默认字符集更改为my.cnf中的UTF-8?

EN

回答 1

Stack Overflow用户

发布于 2022-06-14 11:41:25

您可以通过在“由服务器为每个连接的客户端执行的字符串”配置文件的[mysqld]部分中包括这一行来配置my.cnf:

代码语言:javascript
运行
复制
[mysqld]
init_connect='SET collation_connection = utf8mb4_unicode_ci;'

也许最好使用SET NAMES (details 这里):

代码语言:javascript
运行
复制
[mysqld]
init_connect='SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci;'

若要设置新表的默认字符集和排序规则,请指定:

代码语言:javascript
运行
复制
[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci

参考手册解释道:

如果在CREATE语句中未指定数据库字符集和排序规则,则使用服务器字符集和排序规则作为默认值。他们没有别的目的。

考虑使用utf8mb4而不是utf8。参考这里

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35344625

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档