Ruby on rails postgres uncent函数与RoR音译

Ruby on rails postgres uncent函数与RoR音译,ruby-on-rails,postgresql,unaccent,Ruby On Rails,Postgresql,Unaccent,在RoR项目中,我们使用postgres uncent函数来检索一个models name属性的uncent版本。name属性可以包含来自各种语言的任何重音字符。然后将其保存为uncent_name属性。我不喜欢这个解决方案,因为我们需要确保已安装并可访问postgres extension Uncent(在测试、移动/清理数据库等时) 在RoR中有ActiveSupport::Incomector.transliterate方法,它应该做一些非常类似的事情 我发现它大多以相同的方式翻译重音字符

在RoR项目中,我们使用postgres uncent函数来检索一个models name属性的uncent版本。name属性可以包含来自各种语言的任何重音字符。然后将其保存为uncent_name属性。我不喜欢这个解决方案,因为我们需要确保已安装并可访问postgres extension Uncent(在测试、移动/清理数据库等时)

在RoR中有ActiveSupport::Incomector.transliterate方法,它应该做一些非常类似的事情

我发现它大多以相同的方式翻译重音字符,但也有一些不同:

同样的结果:

SELECT unaccent('ľščťžý') AS unaccent_name;
=> "lsctzy"
ActiveSupport::Inflector.transliterate('ľščťžý')
=> "lsctzy"
不同的结果:

SELECT unaccent('ß') AS unaccent_name;
=> "S"
ActiveSupport::Inflector.transliterate('ß')
=> "ss"
我知道这两种方法都可以接受带有自定义字母替换的词典,但我只对它们的常规/默认用法感兴趣


音译法的主要目的是否与postgres uncent函数相同?我们可以用它代替吗?

非常旧的帖子,但我正在解决一个类似于OP的问题。我们希望能够搜索一个名字并进行音译,以获得更好的结果。然而,在我们版本的Postgres和rails中,字符将相同的音译为“ss”

我只是想和大家分享一下我的发现,以防它对其他偶然发现这篇文章的人有用

在rails 5.2中:

irb(main):001:0> ActiveSupport::Inflector.transliterate('ß')
=> "ss"
在postgres 9.6中,我得到:

db-test=# SELECT unaccent('ß') AS unaccent_name;
 unaccent_name 
---------------
 ss
(1 row)