MYSQL utf8mb4 插入emoji表情乱码

WBOY
Freigeben: 2016-08-04 09:21:14
Original
1546 Leute haben es durchsucht

关于MYSQL utf8mb4字符串集的问题。

表结构如下:

MYSQL utf8mb4 插入emoji表情乱码

如下代码:

<code class="php">$db     = new mysqli('x', 'xxx', 'xxxxx');
$db->select_db('xxx');
$db->set_charset('utf8mb4');

//这里是一个emoji表情
$contents = query($sql);
print_r($db->error_list);
echo "\t\n";
exit();</code>
Nach dem Login kopieren
Nach dem Login kopieren

但是入库后,是一个? 如下图:

MYSQL utf8mb4 插入emoji表情乱码

求解决。

回复内容:

关于MYSQL utf8mb4字符串集的问题。

表结构如下:

MYSQL utf8mb4 插入emoji表情乱码

如下代码:

<code class="php">$db     = new mysqli('x', 'xxx', 'xxxxx');
$db->select_db('xxx');
$db->set_charset('utf8mb4');

//这里是一个emoji表情
$contents = query($sql);
print_r($db->error_list);
echo "\t\n";
exit();</code>
Nach dem Login kopieren
Nach dem Login kopieren

但是入库后,是一个? 如下图:

MYSQL utf8mb4 插入emoji表情乱码

求解决。

这样是对的。
说下前提,utf8mb4和utf8的区别就是utf8才用3位字节码存储数据,而utf8mb4用4位字节码存储数据。
emoji表情是4位字节码通过前段转义出来的,它本身是不可读的字符,所以在数据库客户端中会显示“?”。
在前端支持emoji的地方就会显示emoji表情。

确定下客户端是否支持utf8mb4,最好使用的时候 set names下。

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!