在MySQL中存储表情符号

时间:2015-04-16 17:09:19

标签: mysql encoding character-encoding

我现在知道,为了在MySQL中正确存储Emojis,编​​码和校对必须设置为'utf8mb4'。问题是我的数据库中已经插入了很多行,而表没有正确的编码和排序规则。是否有任何方法可以使用行中的当前信息来更新每一行,以便显示表情符号?

我将排序规则和编码更改为正确的值。但是,我似乎无法做到

 $sql = "SELECT * FROM users";
 $result = mysqli_query($con, $sql);
 $count = mysqli_num_rows($result);
 $i = 0;

 while($row = mysqli_fetch_array($result)) { 
     $id[$i] = $row['id'];
     $bio[$i] = $row['bio'];

    $i++;
} 

for($i=0;$i<$count;$i++) {
    $sql = "UPDATE users SET bio = '".$bio[$i]."' WHERE id = '".$id[$i]."'";
    mysqli_query($con, $sql);   
}

我希望只查询所有行并更新每一行,因为我有正确的设置。但是,即使在更新每一行之后,也不会出现表情符号。有什么想法吗?

1 个答案:

答案 0 :(得分:1)

假设您已正确设置数据库,表和列的编码和排序规则属性,那么您不需要查询所有行并重新更新它们。

首先要尝试的是通过添加:

来指定PHP客户端连接中的字符集
mysqli_set_charset($your_mysqli_connect_link, 'utf8mb4');

在进行任何mysqli_query()来电之前。

现在确保您在服务器端也正确设置了所有字符集和排序规则属性。在CLI上试试这个:

mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' 
       OR Variable_name LIKE 'collation%';
+--------------------------+--------------------+
| Variable_name            | Value              |
+--------------------------+--------------------+
| character_set_client     | utf8mb4            |
| character_set_connection | utf8mb4            |
| character_set_database   | utf8mb4            |
| character_set_filesystem | binary             |
| character_set_results    | utf8mb4            |
| character_set_server     | utf8mb4            |
| character_set_system     | utf8               |
| collation_connection     | utf8mb4_unicode_ci |
| collation_database       | utf8mb4_unicode_ci |
| collation_server         | utf8mb4_unicode_ci |
+--------------------------+--------------------+

确保您的/etc/my.conf具有所有正确的配置:

[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