how to make my SQlite query case insensitive?(如何使我的SQlite查询不区分大小写?)
问题描述
我的原始代码是:
String sql = "select t.* from (select dId, " +
"case when substr(dWord, 1, 4) in ('das ', 'der ','die ') " +
"then substr(dWord, 5) else dWord end as dWord " +
"from german) t where t.dWord like '%' || ? || '%' " +
"order by instr(t.dWord, ?), t.dWord";
c = mydb.rawQuery(sql, new String[] {search, search});
例如,当我搜索‘A’时,它会显示所有以大写‘A’开头的单词,按字母顺序排序,然后按字母顺序显示以‘a’开头的单词。但我想将"a"视为"A",并将"A"视为"a"。我应该对代码进行哪些更改?
Edit1=我知道COLLATE NOCASE,但我不知道如何在我的代码中使用它。
推荐答案
将语句的最后一行更改为:
order by instr(lower(t.dWord), lower(?)), lower(t.dWord)
函数lower()
将列值和搜索字符串转换为小写,以模拟函数instr()
内的不区分大小写的比较。
这篇关于如何使我的SQlite查询不区分大小写?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!