Mac

数据库区分巨细写查询 sqlite不区分巨细写查询

字号+ 作者:果小编 来源:原创 2018-02-01 20:00 我要评论()

默认情况下,SQL Server不区分大小写,假设数据表test的name字段中有数据“abcd”和“Abcd”,如果使用查询语句:select ......

默认情况下,SQL Server不区分大小写,假设数据表test的name字段中有数据“abcd”和“Abcd”,如果使用查询语句:select * from test where name like 'a%',则查询的结果会把上面的两条数据都查询出来,这一点上和Oracle有区别.

可以通过设置排序规则使其区分大小写,分别为:创建数据库,修改数据库,创建表的字符型列时指定排序规则来实现

eg:

1.创建数据库区分大小写

create database test collate Chinese_PRC_CS_AS

2.修改数据库区分大小写

alter database test collate Chinese_PRC_CS_AS

3.创建表区分大小写

create table test(tid in primary key, name varchar(20 collate Chinese_PRC_CS_AS))

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

有表test如下:

id name
1 ABCDE
2 abcde
3 ABcde
4 abCDE
5 aaaaa
6 bbbbb

执行下面sql语句

select * from test where name = 'abCDE';

结果是没有查询到任何记录(sqlite在进行字符串查询的时候,默认是区分大小写)

区分大小写的三种解决方案

一:使用大小写转换函数LOWER,UPPER

eg:select * from test where LOWER(name) = 'abcde';

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

select * from test where name = 'abcde' collate nocase;

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

create table test (id integer, name text collate nocase)

注:

(1)不推荐使用方案一,有额外的性能消耗

(2)如果只是少量查询不需要区分大小写,建议使用方案二

(3)在任何情况下都不需要区分大小写,http://www.guopupu.com/iphone/ 序列号,方案三完美献身

转载请注明出处。苹果序列号查询|iphone序列号|微信帮帮|西北大学在线

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
网友点评
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片