【问题标题】:Is it possible to use different collations (per row) or to add your own collation in MySQL?是否可以使用不同的排序规则(每行)或在 MySQL 中添加自己的排序规则?
【发布时间】:2011-04-13 03:56:43
【问题描述】:

问题

一位朋友正在开发a Swedish dictionary web application。一种用途是检查拼字游戏中的单词。 Swedish Scrabble rules(瑞典语)允许例如将“a”和“á”视为同一个字母,但不能将“u”和“û”或“y”和“ü”视为同一个字母。瑞典排序规则 (latin1_swedish_ci) 的想法不同,将 'y' 和 'ü' 视为同一个字母,使单词 'mysli' 匹配为正确的单词,尽管它应该拼写为 'müsli'。

三个建议的解决方案

更新:添加了第三个解决方案提案(粗体)

  1. 对单词表中的不同行使用不同的排序规则。那可能吗?
  2. 克隆瑞典排序规则定义,对其进行编辑并在 MySQL 中使用。这比here 描述的方法更容易吗?
  3. 在表格中添加一个带有特殊词的新列。 列上可能有不同的排序规则,对吧?在两列中搜索单词时,SQL 查询会变得很慢吗?

其他建议?

这个问题可以通过其他方式解决吗?

【问题讨论】:

  • 请查看我的第三点编辑。

标签: mysql collation


【解决方案1】:

到 1.:这是不可能的

to 2.:我不知道 - 我也有兴趣知道这是否可能。

编辑:

to 3.: 是的,这是可能的——它会慢一点,但我想你不会注意到它。 (如果这是唯一的可能,你别无选择)

【讨论】:

  • 我们一直在讨论将表拆分为两个表是否更好,其中一个包含大部分单词,另一个包含特殊单词。我想这或多或少只是 3 的另一个版本。
猜你喜欢
  • 2013-06-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-04-26
  • 2023-04-11
  • 2011-11-14
  • 2011-08-18
相关资源
最近更新 更多