首页 > 开发 > 综合 > 正文

查询区分大小写

2024-07-21 02:08:24
字体:
来源:转载
供稿:网友

在sql2000和7.0的查询语句中,区分大写的查询方法

--sql2000,就用下面的方法.
--就是在字段名后加 collate chinese_prc_cs_as_ws


--区分大小写、全半角字符的方法

--测试数据
create table 表(fd varchar(10))
insert into 表
select aa='aa'
union all select 'aa'
union all select 'aa'   --全角a
union all select 'a,a'  --全角a,半角,
union all select 'a,a' --全角a,全角,
go

--查询
--1.查大写字母
select * from 表
where fd collate chinese_prc_cs_as_ws like '%a%' 
--就是在字段名后加 collate chinese_prc_cs_as_ws

--2.查全角
select * from 表
where fd collate chinese_prc_cs_as_ws like '%a%'

--3.查半角
select * from 表
where fd collate chinese_prc_cs_as_ws like '%,%'
go

--删除测试数据
drop table 表

/*--测试结果

1.查询大写字母的结果
fd        
----------
aa


2.查询全角字符的结果
fd        
----------
aa
a,a
a,a


3.查询半角字符的结果
fd        
----------
a,a

(所影响的行数为 1 行)
--*/


================================================================

--sql7.0,就用下面的方法.

--如果是全部比较
--下面是测试
select * from(
select fd='a'
union all select 'a'
) a
where cast(fd as varbinary(8000))=cast('a' as varbinary(8000))

/*--测试结果
fd  
----
a

(所影响的行数为 1 行)
--*/

--如果是部分匹配,就用charindex:

--下面是测试
select * from(
select fd='a'
union all select 'a'
union all select 'aaaa'
union all select 'aaaa'
union all select 'ccca'
) a
where charindex(cast('a' as varbinary(8000)),cast(fd as varbinary(8000)))>0

/*--测试结果
fd  
----
a
aaaa
ccca

(所影响的行数为 3 行)
--*/

 

 
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表