我是MySQL
的新手。我有一个列存储Unicode character
在MySQL
表
我有一个代码,从twitter,facebook
等获得帖子在表中插入text/symbol
。
CREATE TABLE `tbl_unicode` (
`_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
`first_name` varchar(45) NOT NULL,
`uninoce_Column` varchar(200) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL,
PRIMARY KEY (`_id`)
) ENGINE=InnoDB AUTO_INCREMENT=201 DEFAULT CHARSET=utf8;
/* This query WONT work due to SYMBOL:💏 */
INSERT INTO `tbl_unicode`
(`_id`,
`first_name`,
`uninoce_Column`)
VALUES
(2,
'rakesh',
'最高の休日💏
#京都#宮津#天の橋立#');
/* This query WORKS FINE */
INSERT INTO `tbl_unicode`
(`_id`,
`first_name`,
`uninoce_Column`)
VALUES
(1,
'shekhar',
'最高の休日
#京都#宮津#天の橋立#');
enter code here
SQLFiddle的实时演示
那么,我应该使用哪种数据类型或配置才能使其工作
有什么建议吗?
字符集utf8
MySQL的utf8
字符集不是UTF-8。那太容易了!相反,它是UTF-8的一个有限子集,其中只支持高达U+00FFFF的代码点,可以存储在三个UTF-8字节中。💏是U+01F48F,所以它不适合表的字符集。
真正的 UTF-8字符集在MySQL(5.5及更高版本)中称为utf8mb4
。
使用nvarchar
作为表字段的数据类型。varchar
只存储8位字符,而nvarchar
也存储unicode字符。