我有一个列,其中一些元素包含重音字母.
例如:Grambú
例如:Grambú
我的要求是,当我搜索“Grambu”时,我也应该在结果中获得“Grambú”.
对于此要求,我尝试对该特定列使用“COLLATE NOCASE”参数.
但那没有用.
当我在网上搜索解决方案时,我发现很多人建议对重音字符进行规范化
并基于它创建另一列作为唯一选项.
这个问题还有其他更简单的解决方案吗?
解决方法
COLLATE NOCASE工作
only for the 26 upper case characters of ASCII.
使用setLocale()
将数据库的语言环境设置为具有重音字符支持的语言环境,并使用COLLATE LOCALIZED.
您也可以尝试使用COLLATE UNICODE
.
但要注意这个错误:SQLite UNICODE sort broken in ICS – no longer case-insensitive.
检查the documentation,提及Android中的这两个合作者.