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


猜你喜欢
- 在测试浓缩咖啡时,Android设备不会在屏幕上启动活动 2022-01-01
- Android - 拆分 Drawable 2022-01-01
- Android viewpager检测滑动超出范围 2022-01-01
- MalformedJsonException:在第1行第1列路径中使用JsonReader.setLenient(True)接受格式错误的JSON 2022-01-01
- 用 Swift 实现 UITextFieldDelegate 2022-01-01
- 使用自定义动画时在 iOS9 上忽略 edgesForExtendedLayout 2022-01-01
- 想使用ViewPager,无法识别android.support.*? 2022-01-01
- android 4中的android RadioButton问题 2022-01-01
- Android - 我如何找出用户有多少未读电子邮件? 2022-01-01
- 如何检查发送到 Android 应用程序的 Firebase 消息的传递状态? 2022-01-01