首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否有不合并重音字符的MySQL utf8排序规则?

是否有不合并重音字符的MySQL utf8排序规则?
EN

Stack Overflow用户
提问于 2011-07-09 11:13:38
回答 2查看 821关注 0票数 4

我有一个utf8表,存储的数据如下:

代码语言:javascript
复制
+-------+--------+
| name  | gender |
+-------+--------+
| ESMÉ  | F      | 
| ESME  | F      | 
+-------+--------+

然而,当我试图在(姓名,性别)上添加一个唯一键时,这两行违反了约束。我已经能够使用utf8_bin排序规则来实现我的目标,但是之后我就不再区分大小写。

所以我想我真正要找的是一种存储utf8数据的方法,而不是让重音字符和非重音字符在我的唯一键中被视为等价的。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-07-12 05:01:49

我不认为你想要的是直接可能的。排序规则确定对日期进行排序和比较的方式。对于您的键,您希望将两个值视为不同的值,但在常规比较中,您希望将它们视为相同的值。

不过,在指定查询时有一个技巧:只将结果转换为utf8,而不指定排序规则。这将转换结果并将排序规则设置回默认值。

下面的示例向您展示了我的意思:

代码语言:javascript
复制
mysql> show create table test_col;
+----------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table    | Create Table                                                                                                                                                        |
+----------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| test_col | CREATE TABLE `test_col` (
  `name` varchar(200) COLLATE utf8_bin DEFAULT NULL,
  UNIQUE KEY `ixuniq` (`name`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin |
+----------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

mysql> insert into test_col (name) values ('Y'),(unhex('c39d'));Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> select * from test_col;
+------+
| name |
+------+
| Y    |
| Ý   |
+------+
2 rows in set (0.00 sec)

mysql> select * from test_col where name='Y';
+------+
| name |
+------+
| Y    |
+------+
1 row in set (0.00 sec)

mysql> select * from test_col where convert(name using 'utf8')='y';+------+
| name |
+------+
| Y    |
| Ý   |
+------+
2 rows in set (0.00 sec)
票数 1
EN

Stack Overflow用户

发布于 2012-05-23 20:50:24

我有完全相同的问题,排序规则在拉丁语中存在,它是latin1_general_ci,但在utf8中不存在。您有3种解决方案:

  • 使用拉丁文
  • 创建或查找创建了归类http://dev.mysql.com/doc/refman/5.0/en/ldml-collation-example.html的人(并让我知道;-)
  • 在比较字符(或插入字符)时使用大写
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6632480

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档