未加星标

表情在 MySQL 的存储详解

字体大小 | |
[数据库(mysql) 所属分类 数据库(mysql) | 发布者 店小二03 | 时间 2016 | 作者 红领巾 ] 0人收藏点击收藏

mysql支持android和ios表情,需要做一些特别处理。

普通的字符串或者表情都是占位3个字节,所以utf8足够了,但是移动端的表情符号占位是4个字节,普通的utf8就不够用了。

utf8mb4方案

数据库采用utf8mb4字符集。

首先,修改数据库的字符集utf8mb4,修改 my.cnf。

[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 init_connect='SET NAMES utf8mb4'

然后,重启 MySQL Server

最后,修改表字段字符集为utf8mb4

ALTER TABLE APP_COMMENT MODIFY `CONTENT` TEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci COMMENT '评论内容';

此时,MySQL已经支持表情存储了。

Blob的二进制存储方案

上面的方案是一种不错的选择,但是目前我们生产环境采用多租户的方式,不能因为我们的产品需要支持表情存储,就让运维人员去修改数据库配置呀,这样具有很高的运维成本,同时可能影响到其他正在使用的产品,具有一定的风险性。

因此,我们衍生出了第二种解决方案 : 采用blob作为字段类型,通过二进制存储方案。这种方案对现有的产品影响最小, 新增 和 更新 的时候,不需要特别处理,在 查询 的时候,将其进行转码即可。

首先,定义blob类型。

COMMENT blob NOT NULL COMMENT '评论内容'

在查询的时候,通过java进行转码

public List findAppCommentList(AppComment appComment, int offset, int limit) { List args = new ArrayList(); StringBuffer sql = new StringBuffer(); sql.append(" select * from app_comment where app_id = ? limit ?,? "); args.add(appComment.getAppId()); args.add(offset); args.add(limit); return this.jdbcTemplate.query(sql.toString(), new RowMapper ({ @Override public AppComment mapRow(ResultSet rs, int rowNum) throws SQLException{ AppComment appComment = new AppComment(); Blob bContent = rs.getBlob("content"); try { appComment.setContent(new String(bContent.getBytes(1, (int) bContent.length()), "utf-8")); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } appComment.setId(rs.getLong("id")); appComment.setUserId(rs.getString("user_id")); appComment.setAppId(rs.getLong("app_id")); //… return appComment; } }, args.toArray()); }

我来大概解释下,上面的含义。

我们,先通过Spring JDBC获取Blob对象。

Blob bContent = rs.getBlob("content");

接着,进行最核心的操作,转码,这样就可以保证二进制内容序列化成utf-8编码的字符串了。

appComment.setContent(new String(bContent.getBytes(1, (int) bContent.length()), "utf-8"));

这样,就能保证MySQL支持表情数据。

本文数据库(mysql)相关术语:navicat for mysql mysql workbench mysql数据库 mysql 存储过程 mysql安装图解 mysql教程 mysql 管理工具

分页:12
转载请注明
本文标题:表情在 MySQL 的存储详解
本站链接:http://www.codesec.net/view/484884.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 数据库(mysql) | 评论(0) | 阅读(19)