微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

android – 通过带有重音字符的列排序sqlite的问题(Á)

我有一个sqlite数据库,我需要通过一个有一些以重音字符开头的单词的列来排序.这些物品订购错误,它们出现在结果的最后:

安东尼奥
BONZO
Zeto
安吉拉

sqlite数据库在该列中有重音时,如何正确订购?

谢谢

解决方法

... ORDER BY column COLLATE UNICODE

要么

... ORDER BY column COLLATE LOCALIZED

Reference:

In addition to sqlite’s default BINARY collator,Android supplies two more,LOCALIZED,which changes with the system’s current locale,and UNICODE,which is the Unicode Collation Algorithm and not tailored to the current locale.

例:

db.execsql("CREATE TABLE foo(a TEXT);");
db.execsql("INSERT INTO foo VALUES('Antonio'),('Bonzo'),('Zeto'),('Ángela');");

Cursor c = db.rawQuery("SELECT * FROM foo ORDER BY a COLLATE UNICODE",null);
while (c.movetoNext()) {
   Log.d("foo",c.getString(0));
}

输出

Ángela
Antonio
Bonzo
Zeto

原文地址:https://www.jb51.cc/android/311154.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐