• SQLite区分大小写查询


    http://www.cnblogs.com/zhuawang/archive/2013/01/15/2861566.html

    大部分数据库在进行字符串比较的时候,对大小写是不敏感的。
    但是,在SQLite中,对大小写是敏感的。

    假设表Test的结构和值如下:

     

    _id  name
    1 ABCDE
    2 abcde
    3 ABCde
    4 abCDE
    5 aaaaa
    6 bbbbb

     
    执行下面的SQL语句:

    select * from test where name = 'Abcde';

    结果是没有查询到任何记录。

    明显地,SQLite在进行字符串比较的时候,默认对大小写是敏感的

     

    那么SQLite怎么区分大小写查询呢,以下是三种解决方案:

     

    方案一:使用大小写转换函数LOWER、UPPER

    1.select * from test where LOWER(name) = 'abcde';

    2.select * from test where LOWER(name) = LOWER('ABCDE');

    3.select * from test where LOWER(name) = LOWER('Abcde');

    4.select * from test where LOWER(name) = LOWER('ABCde');

     ....

    (1).select * from test where UPPER(name) = 'ABCDE';

    (2).select * from test where UPPER(name) = UPPER('ABCDE');

    (3).select * from test where UPPER(name) = UPPER('Abcde');

    (4).select * from test where UPPER(name) = UPPER('ABCde');

    .....

    查询到的记录都如下:

     

    1 ABCDE
    2 abcde
    3 ABCde
    4 abCDE

     

    方案二:在进行比较时强制声明不区分大小写

    select * from test where name = 'ABCDE' COLLATE NOCASE;

    查询到的记录如下:

     

    1 ABCDE
    2 abcde
    3 ABCde
    4 abCDE

     

    方案三:创建表时声明该字段不区分大小写

    create table test (_id Integer,name Text COLLATE NOCASE );

     

    如果在任何情况下都不需要对大小写敏感,方案三是最好的解决方案;

    如果只是少量查询对大小写不敏感,可以用方案二。

    而方案一由于用到了函数,可能有额外的性能消耗,不推荐使用。

  • 相关阅读:
    WinForm开发中几种找控件的方法
    C#读取Excel文件时提示:无法指出的错误
    数据库中取随机记录的方法
    C#写数据到Excel
    从数据库导出数据到word、excel、.txt
    Telerik RadTreeView查寻值的方法
    如何导出WinForm 控件界面的矢量图
    简单数据缓存类(c#)
    Windows Installer 清理实用工具说明
    硬盘安装Win7全攻略
  • 原文地址:https://www.cnblogs.com/liulipeng/p/3431265.html
Copyright © 2020-2023  润新知