关于php7 设计链接mysqlutf8mb4字符集的问题

WBOY
Libérer: 2016-07-06 13:51:30
original
1418 Les gens l'ont consulté

通过epel源安装php7后连接数据库直接提示:

<code>Unable to set client connection character set: utf8mb4</code>
Copier après la connexion
Copier après la connexion

使用utf8则没有报错

找到一种解决方案: 直接使用sql语句设置字符集则

<code>SET NAMES 'utf8mb4';</code>
Copier après la connexion
Copier après la connexion

但是使用这种方法, 总感觉不好, 而且之前代码需要改动的地方也不少, 有点划不来

大大们, 有解决方案吗, 这里先谢过了

PS: 没辙google了一天都没有找到解决方案, 不过估计是很傻B的问题

================================================================

问题原因找到了, 果然只是配置的问题

<code>$pdo = new PDO('mysql:host=localhost;dbname=my_db;charset=utf8mb4', 'db_user', 'db_password');</code>
Copier après la connexion
Copier après la connexion

to:

<code>$pdo = new PDO('mysql:host=localhost;dbname=my_db', 'db_user', 'db_password', array(
    PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8mb4',
));</code>
Copier après la connexion
Copier après la connexion

不知道为啥新版本的pdo的驱动无法直接设置连接字符集为utf8mb4, 讲道理应该是向后兼容才对的, 不过至少找到解决方案了 :-D

回复内容:

通过epel源安装php7后连接数据库直接提示:

<code>Unable to set client connection character set: utf8mb4</code>
Copier après la connexion
Copier après la connexion

使用utf8则没有报错

找到一种解决方案: 直接使用sql语句设置字符集则

<code>SET NAMES 'utf8mb4';</code>
Copier après la connexion
Copier après la connexion

但是使用这种方法, 总感觉不好, 而且之前代码需要改动的地方也不少, 有点划不来

大大们, 有解决方案吗, 这里先谢过了

PS: 没辙google了一天都没有找到解决方案, 不过估计是很傻B的问题

================================================================

问题原因找到了, 果然只是配置的问题

<code>$pdo = new PDO('mysql:host=localhost;dbname=my_db;charset=utf8mb4', 'db_user', 'db_password');</code>
Copier après la connexion
Copier après la connexion

to:

<code>$pdo = new PDO('mysql:host=localhost;dbname=my_db', 'db_user', 'db_password', array(
    PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8mb4',
));</code>
Copier après la connexion
Copier après la connexion

不知道为啥新版本的pdo的驱动无法直接设置连接字符集为utf8mb4, 讲道理应该是向后兼容才对的, 不过至少找到解决方案了 :-D

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!