MYSQL 5.5 之前, UTF8 编码只支持1-3个字节,只支持BMP这部分的unicode编码区, BMP是从哪到哪,到http://en.wikipedia.org/wiki/Mapping_of_Unicode_characters这里看,基本就是0000~FFFF这一区。 从MYSQL5.5开始,可支持4个字节UTF编码utf8mb4,一个字符最多能有4字节,所以能支持更多的字符集。

utf8mb4 is a superset of utf8

utf8mb4兼容utf8,且比utf8能表示更多的字符。

至于什么时候用,看你的做什么项目了。。

在做移动应用时,会遇到ios用户会在文本的区域输入emoji表情,如果不做一定处理,就会导致插入数据库异常。

Emoji表情符号兼容方案

一 什么是Emoji

emoji就是表情符号;词义来自日语(えもじ,e-moji,moji在日语中的含义是字符)

表情符号现已普遍应用于手机短信和网络聊天软件。

emoji表情符号,在外国的手机短信里面已经是很流行使用的一种表情。

手机上如何使用emoji:

1.iphone、ipad系统:安装emoji free,再设置-通用-键盘-国际键盘-添加新的键盘,然后把emoji添加在里面即可在发短信和一些输入文本的文本框中输入表情。

IOS 5用户可直接从通用中添加emoji 键盘,无需再安装emoji free

2.android系统:安装“GO输入法国际版”后,在输入法里面点选安装emoji插件可以使用。另外“百度输入法”也自带emoji表情

3.Windows Phone : 安装此 Emoji Keys,在其中输入之后复制粘贴到需要输入表情的地方即可

二 Emoji表情符号问题

1 问题:

IOS版本之间发送的Emoji表情符号不兼容,只看到方块

不同IOS版本在数据库存数据时,有时会发生系统错误

2 现象:

IOS 4 输入Emoji表情符,在IOS5.01 显示正常,在IOS5.1中(大陆版)显现为方块, 但IOS5.01/5.1输入的表情符号,显示正      常

IOS5.01/5.1 输入表情符,在IOS5.01/5.1中显示正常,但在IOS4.X显示为方块

输入Emoji入帖子正文, 可正常存储。 但用户昵称在IOS4.X 输入Emoji,系统正常, 而IOS5.01/5.1则提示系统错误。

3 本质:

iOS 5 and OS X 10.7 (Lion) use the Unicode 6.0 standard ‘unified’ code points for emoji.

iOS 5 Emoji  采用Unicode 6 标准来统一code points

iOS 4 on SoftBank iPhones used a set of unofficial code points in the Unicode Private Use Area, and so aren’t      compatible with any other systems

iOS 4 采用SoftBank Unicode, 一种非官方的, 采用私有Unicode 区域。

4 举例:

one emoji symbol “tiger”, it is “\U0001f42f” in iOS5, but “\ue050” in earlier iOS version

虎脸Emoji符号在iOS5 为Unicode:\U0001f42f;而在IOS4.x 为:\ue050 (SoftBank 编码)

另外: 按理讲, 从iOS5 应该兼容以前版本的emoji, 但现在出现5.01版本完美兼容(无论大陆版,美版,还是港版), 而5.1     大陆版出现了不兼容现象(腾讯微信也出现了同样的问题)。

三 问题分析

1 系统存储错误问题(如昵称,帖子内容)

原因:

由于IOS5.X 采用新的Unicode, 其UTF8 编码大多为4个字节, 而由于昵称/帖子内容column并没设成utf8mb4,因此存储会    发生错误。

解决方法:

将昵称/帖子内容设成utf8mb4

2 不同iOS 之间Emoji 不兼容的问题。

原因:

iOS 5 到4 不兼容的问题,很简单,unicode6 和softbank编码的不同

iOS 4 到 5,按理说应该兼容,也就是说,iOS应该自动判断如果是softbank编码,自动转成unicode6。但现在看来, iOS5.1(大陆版)好像只支持unicode6, 而不支持softbank.

解决方法:

客户端发送emoji-encoding: Softbank或unicode6, 由服务端分别给出相应的编码表。

四 解决方案

1 数据存储(MySQL varchar  数据类型对UTF8 支持问题)

MYSQL 5.5 之前, UTF8 编码只支持1-3个字节, 从MYSQL5.5开始,可支持4个字节UTF编码,但要特殊标记。例如我们的帖子内容项,我们加上了这个支持。服务端mysql统一存储为ios5.x也就是Unicode编码。

对应alter语句:

ALTER TABLE topic MODIFY COLUMN content varchar(500) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT ‘内容’;

2 编码转换:

iphone手机方案

客户端输入内容时候,统一存储为unicode编码(这里需要从softbank编码转换为unicode编码)。客户端请求内容的时候,需要根据不同的客户端给出不同的编码,ios4采用softbank编码做替换,ios5采用unicode编码直接支持。

android或wp其他手机方案:

如果没有emoji表情库,将无法输入。针对输入问题,将统一采用unicode编码存储。客户端请求内容的时候,将统一用softbank编码,客户端需要把emoji表情符号内置到客户端,做对应的编码和img替换。

web解决方案:

参考android或wp其他手机方案

五 部分代码

1 sql代码

CREATE TABLE `ios_emoji` (

`id` int(11) NOT NULL AUTO_INCREMENT COMMENT ‘自增ID’,

`unicode` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT ‘Unicode编码’,

`utf8` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT ‘UTF8编码’,

`utf16` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT ‘UTF16编码’,

`sbunicode` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT ‘SBUnicode编码’,

`filename` varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci DEFAULT NULL COMMENT ‘文件名’,

`filebyte` longblob COMMENT ‘文件内容字节’,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT COMMENT=’ios表情编码表’;

2 java代码

import java.io.UnsupportedEncodingException;

import org.apache.commons.lang.StringUtils;

public class IOSEmojiUtil {

public static String[] ios5emoji ;

public static String[] ios4emoji ;

public static String[] androidnullemoji ;

public static String[] adsbuniemoji;

public static void initios5emoji(String[] i5emj,String[] i4emj,String[] adnullemoji,String[] adsbemoji){

ios5emoji = i5emj;

ios4emoji = i4emj;

androidnullemoji = adnullemoji;

adsbuniemoji = adsbemoji;

}

//在ios上将ios5转换为ios4编码

public static String transToIOS4emoji(String src) {

return StringUtils.replaceEach(src, ios5emoji, ios4emoji);

}

//在ios上将ios4转换为ios5编码

public static String transToIOS5emoji(String src) {

return StringUtils.replaceEach(src, ios4emoji, ios5emoji);

}

//在android上将ios5的表情符替换为空

public static String transToAndroidemojiNull(String src) {

return StringUtils.replaceEach(src, ios5emoji, androidnullemoji);

}

//在android上将ios5的表情符替换为SBUNICODE

public static String transToAndroidemojiSB(String src) {

return StringUtils.replaceEach(src, ios5emoji, adsbuniemoji);

}

//在android上将SBUNICODE的表情符替换为ios5

public static String transSBToIOS5emoji(String src) {

return StringUtils.replaceEach(src, adsbuniemoji, ios5emoji);

}

//eg. param: 0xF0 0x9F 0x8F 0x80

public static String hexstr2String(String hexstr) throws UnsupportedEncodingException{

byte[] b = hexstr2bytes(hexstr);

return new String(b, “UTF-8”);

}

//eg. param: E018

public static String sbunicode2utfString(String sbhexstr) throws UnsupportedEncodingException{

byte[] b = sbunicode2utfbytes(sbhexstr);

return new String(b, “UTF-8”);

}

//eg. param: 0xF0 0x9F 0x8F 0x80

public static byte[] hexstr2bytes(String hexstr){

String[] hexstrs = hexstr.split(” “);

byte[] b = new byte[hexstrs.length];

for(int i=0;i

b[i] = hexStringToByte(hexstrs[i].substring(2))[0];

}

return b;

}

//eg. param: E018

public static byte[] sbunicode2utfbytes(String sbhexstr) throws UnsupportedEncodingException{

int inthex = Integer.parseInt(sbhexstr, 16);

char[] schar = {(char)inthex};

byte[] b = (new String(schar)).getBytes(“UTF-8”);

return b;

}

public static byte[] hexStringToByte(String hex) {

int len = (hex.length() / 2);

byte[] result = new byte[len];

char[] achar = hex.toCharArray();

for (int i = 0; i

int pos = i * 2;

result[i] = (byte) (toByte(achar[pos]) <

}

return result;

}

private static byte toByte(char c) {

byte b = (byte) “0123456789ABCDEF”.indexOf(c);

return b;

}

public static void main(String[] args) throws UnsupportedEncodingException {

// TODO Auto-generated method stub

byte[] b1 = {-30,-102,-67}; //ios5 //0xE2 0x9A 0xBD

byte[] b2 = {-18,-128,-104}; //ios4 //”E018″

//————————————-

byte[] b3 = {-16,-97,-113,-128};    //0xF0 0x9F 0x8F 0x80

byte[] b4 = {-18,-112,-86};         //E42A

ios5emoji = new String[]{new String(b1,”utf-8″),new String(b3,”utf-8″)};

ios4emoji = new String[]{new String(b2,”utf-8″),new String(b4,”utf-8″)};

//测试字符串

byte[] testbytes = {105,111,115,-30,-102,-67,32,36,-18,-128,-104,32,36,-16,-97,-113,-128,32,36,-18,-112,-86};

String tmpstr = new String(testbytes,”utf-8″);

System.out.println(tmpstr);

//转成ios4的表情

String ios4str = transToIOS5emoji(tmpstr);

byte[] tmp = ios4str.getBytes();

//System.out.print(new String(tmp,”utf-8″));

for(byte b:tmp){

System.out.print(b);

System.out.print(” “);

}

}

}

六 参考资料

1 Emoji 全编码表:(我参考的这个)

http://punchdrunker.github.com/iOSEmoji/table_html/flower.html

2 Emoji全编码表

http://code.iamcal.com/php/emoji/

3 iOS5/4 Emoji  兼容性:

http://stackoverflow.com/questions/7856775/how-to-convert-the-old-emoji-encoding-to-the-latest-encoding-in-ios5

4 MySQL emoji问题

http://dropblood.com/archives/ios-mysql-emoji

5 Emoji 中文对应表

http://www.iapps.im/wp-content/uploads/2012/02/emoji-pinyin.png?r=010

七 下载资源

emoji图片和编码表 http://download.csdn.net/detail/qdkfriend/4309051

包括emoji文件表,emoji数据编码表(Unicode编码,UTF8编码,UTF16编码,SBUnicode编码)

mysql支持utf8mb4升级方案

[http://mathiasbynens.be/notes/mysql-utf8mb4#utf8-to-utf8mb4](

How to support full Unicode in MySQL databases

)

link: http://my.oschina.net/wingyiu/blog/153357

mysql_row百度百科_MySQL相关推荐

  1. 使用CURL构建爬虫,抓取百度百科内容

    实现这个功能的步骤: 首先打开百度百科,在搜索框输入"php"关键词,得到搜索列表,一般都是10条: 然后使用火狐的Firebug分析百度列表的内容组成,主要是html标签,发现去 ...

  2. 爬取百度百科上中国所有城市的信息

    1 # coding=utf-8 2 import xlrd 3 import xlwt 4 import requests 5 import re 6 import json 7 import os ...

  3. 姚殊清华计算机科学与技术,王道顺(清华大学计算机科学与技术系副教授)_百度百科...

    王道顺 (清华大学计算机科学与技术系副教授) 语音 编辑 锁定 讨论 上传视频 王道顺,毕业于四川大学理学博士 (应用数学),现为 清华大学计算机科学与技术系副教授. 中文名 王道顺毕业院校 职    ...

  4. python编程中文版百度百科_1.2 搭建python+pycharm编程开发环境

    工欲善其事必先利其器,很多小伙伴在学习编程的道路上,第一步就被编程环境搭建劝退.今天就让我们起来快速搭建一个python的开发环境,开启征服python的第一步. 一.Python安装 1.1pyth ...

  5. 【网络爬虫】BeautfulSoup爬百度百科(真の能看懂~!)

    文章目录 1 百度百科 2 观看规律 3 制作爬虫 4 结果 1 百度百科 百度百科中有很多名词的解释信息, 我们今天从 "网页爬虫" 的词条开始爬, 然后在页面中任意寻找下一个词 ...

  6. python爬虫百度百科-如何入门 Python 爬虫?

    目前网上有关网页爬虫的指导有很多,但是套路却是千篇一律,基本都是围绕以下内容进行展开,CSS/html等网页知识 requests或urllib BeautifulSoup或正则表达式 Seleniu ...

  7. python语言百度百科-Python 语言下数据驱动DDT的应用

    数据驱动测试的含义: 在百度百科上的解释是: 数据驱动测试,即黑盒测试(Black-box Testing),又称为功能测试,是把测试对象看作一个黑盒子.利用黑盒测试法进行动态测试时,需要测试软件产品 ...

  8. 用python 爬取百度百科内容-爬虫实战(一) 用Python爬取百度百科

    最近博主遇到这样一个需求:当用户输入一个词语时,返回这个词语的解释 我的第一个想法是做一个数据库,把常用的词语和词语的解释放到数据库里面,当用户查询时直接读取数据库结果 但是自己又没有心思做这样一个数 ...

  9. python爬虫百度百科-python爬虫(一)_爬虫原理和数据抓取

    本篇将开始介绍Python原理,更多内容请参考:Python学习指南 为什么要做爬虫 著名的革命家.思想家.政治家.战略家.社会改革的主要领导人物马云曾经在2015年提到由IT转到DT,何谓DT,DT ...

最新文章

  1. 控制~线性二次型最优控制
  2. element 表格宽度自适应_Python如何以表格形式打印输出!
  3. linux 调用默认程序打开文件,Excel VBA如何使用默认应用程序打开文件
  4. 内存spd规范_C语言内存泄露很严重,如何应对?
  5. 还在买白酒?算法工程师们,量化投资了解一下
  6. php类中双冒号和-的区别
  7. linux-压缩与解压缩
  8. android弹窗不能手动关闭_3大类APP弹窗提醒方式总结
  9. HOJ 2275 Number sequence
  10. 静态HTML网页作业模板 华为企业网站设计作品 静态学生网页设计作业简单网页制作
  11. c语言如何输出动态数组,C语言动态数组的使用实现代码
  12. 如何使用STVP烧录程序
  13. 【将Cityscape和Foggy_Cityscape转换为PASACAL VOC格式的目标检测数据集】
  14. 张子阳:如何在30岁前年薪超过30万
  15. “鹏城”伴你鹏程:下届全国人工智能大赛再会!
  16. 15_岭回归-Ridge、岭回归API、线性回归和岭回归的对别;逻辑回归、sigmoid函数、逻辑回归公式、损失函数、逻辑回归API、逻辑回归案例、逻辑回归的优缺点、逻辑回归 VS 线性回归等
  17. 联想笔记本电脑insert键占用,当鼠标变成小方块时,如何解决
  18. windowsPE制作工具
  19. 查询mysql索引信息_数据查询优化之mysql索引
  20. Google Chrome浏览器字体模糊,字体锯齿 的解决方法

热门文章

  1. 抖音1元秒杀活动背后赚钱秘诀是什么? 怎么个玩法?
  2. C#的多线程(2)之二
  3. Ubuntu16.04安装labelImg,报错Cannot mix incompatible Qt library (version 0x50a00) with this library (vers
  4. 计算税率c语言编写程序,C语言编写一个计算个人所得税的程序,要求输入收入金额,能够输...
  5. matlab humoments,应用于数字图像识别的Hu矩缩放不变性分析
  6. 简约大气昼夜wordpress免费导航主题
  7. 今天帮某个女生解决 鼠标无法移动,自己乱动的问题
  8. 【创客空间】相关资料
  9. 鸿蒙5G的营业执照,华为继“鸿蒙”商标后注册“5G”商标
  10. CentOS 7安装ELK日志分析系统