how to make my SQlite query case insensitive?(如何使我的SQlite查询不区分大小写?)

本文介绍了如何使我的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查询不区分大小写?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!