首页 > 后端开发 > php教程 > thinkphp执行'set names utf8mb4'报错

thinkphp执行'set names utf8mb4'报错

WBOY
发布: 2016-10-11 14:23:19
原创
2893 人浏览过

运行环境:sae + thinkphp
DB_CHARSET为utf8;(直接设置为utf8mb4会报错,我也不知道为什么。。。)
想支持emoji表情,测试代码如下
public function test(){

<code>    $model = M('');
    $model -> query('set names utf8mb4');
}</code>
登录后复制
登录后复制

错误提示 : [ SQL语句 ] : set names utf8mb4。
求大神给点指导,谢谢!

回复内容:

运行环境:sae + thinkphp
DB_CHARSET为utf8;(直接设置为utf8mb4会报错,我也不知道为什么。。。)
想支持emoji表情,测试代码如下
public function test(){

<code>    $model = M('');
    $model -> query('set names utf8mb4');
}</code>
登录后复制
登录后复制

错误提示 : [ SQL语句 ] : set names utf8mb4。
求大神给点指导,谢谢!

<code>select version();  看下数据库版本,5.5以上才支持utf8mb4
</code>
登录后复制

Mysql::utf8mb4

1、检查下mysql的版本;
mysql 5.5.3 之后的版本,增加utf8mb4字符集;之前的版本要先升级mysql server。
2、MySQL utf8mb4 字符集
修改 /etc/my.cnf

[client]
default-character-set = utf8mb4

[mysql]
default-character-set = utf8mb4

[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'

重启 MySQL Server、检查字符集

相关标签:
php
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板