• 字符集UTF-8MB4 MySQL utf8mb4 字符集,用于存储emoji表情


    字符集UTF-8MB4

    utf8mb4兼容utf8,且比utf8能表示更多的字符。
    看unicode编码区
    从1 ~ 126就属于传统utf8区,当然utf8mb4也兼容这个区,126行以下就是utf8mb4扩充区,什么时候你需要存储那些字符,你才用utf8mb4,否则只是浪费空间。

    官方地址:http://dev.mysql.com/doc/refman/5.5/en/charset-unicode-utf8mb4.html

    MySQL 要存储emoji表情,因此发现我们常用的utf8 字符集根本无法存储表情。

    首先将我们数据库默认字符集由utf8 更改为utf8mb4,对应的表默认字符集也更改为utf8mb4  已经存储表情的字段默认字符集也做了相应的调整。

    SQL 语句

    1 # 修改数据库:  
    2 ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;  
    3 # 修改表:  
    4 ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;  
    5 # 修改表字段:  
    6 ALTER TABLE table_name CHANGE column_name column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;  

    修改MySQL配置文件

    新增如下参数:

     1 [client]  
     2 default-character-set = utf8mb4  
     3   
     4 [mysql]  
     5 default-character-set = utf8mb4  
     6   
     7 [mysqld]  
     8 character-set-client-handshake = FALSE  
     9 character-set-server = utf8mb4  
    10 collation-server = utf8mb4_unicode_ci  
    11 init_connect='SET NAMES utf8mb4'  

    检查环境变量 和测试 SQL 如下:

     1 mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';  
     2 +--------------------------+--------------------+  
     3 | Variable_name            | Value              |  
     4 +--------------------------+--------------------+  
     5 | character_set_client    | utf8mb4            |  
     6 | character_set_connection | utf8mb4            |  
     7 | character_set_database  | utf8mb4            |  
     8 | character_set_filesystem | binary            |  
     9 | character_set_results    | utf8mb4            |  
    10 | character_set_server    | utf8mb4            |  
    11 | character_set_system    | utf8              |  
    12 | collation_connection    | utf8mb4_unicode_ci |  
    13 | collation_database      | utf8mb4_unicode_ci |  
    14 | collation_server        | utf8mb4_unicode_ci |  
    15 +--------------------------+--------------------+  
    16  rows in set (0.00 sec)  

    MySQL版本必须为5.5.3以上版本,否则不支持字符集utf8mb4

    测试,如下修改亦可

    项目中的配置文件如下修改

    jdbc.driverClassName=com.mysql.jdbc.Driver
    jdbc.url=jdbc:mysql://***.***.***.***:3306/fsmp?useSSL=false
    jdbc.username=***
    jdbc.password=***

     数据库连接池配置

    参考文献:

    http://blog.arkency.com/2015/05/how-to-store-emoji-in-a-rails-app-with-a-mysql-database/

  • 相关阅读:
    eclipse中android单元测试
    以树形结构的形式输出指定目录下面的所有文件
    在一个文件末尾增加字符串,并在控制台打印出来
    读取一个文件的数据经过某种操作,将结果存储到另外一个文件
    读取一个文件中的字符,统计每个字符出现的次数
    合并两个递增排序的链表
    找出单链表的倒数第K个(从1开始计数)结点的值
    反转一个链表并输出各个结点的值
    输入一个有序数组和一个数字,在数组中查找两个数,使得它们的和正好是输入的那个数字
    字符串翻转,单词内不翻转
  • 原文地址:https://www.cnblogs.com/guoziyi/p/6054112.html
Copyright © 2020-2023  润新知