[access查询]FAQ:在查询文本时,如何匹配大小写?
时 间:2007-12-10 09:22:09
作 者:UMVsoft整理 ID:8 城市:上海 QQ:2851379730
摘 要:在查询文本时,如何匹配大小写
正 文:
(Q)
例如:
abc
ABC
kkk
我以'a'为关键字,想只查询到abc这条记录,请问应该如何处理?
我尝试过以下方法可以解决:
Select * From (Select *, iif(Instr(ID,'a') > 0,mid
(ID,Instr(ID,'a'),1), "") as key FROM aaa) Where StrComp
(key, 'a', 0) = 0
不知道是否有其他更好的方法,谢谢
(A)
根据我的经验,Jet SQL中的LIKE语句是不支持区分大小写的。但是,也许我们可以通过其它的方法来在一定程度上实现您所需要的功能。只能说是一定程度上,因为毕竟不可能像LIKE语句那么灵活的实现区分大小写
比如说:您希望实现类似LIKE “a*” 的功能,并且希望他是区分大小写的,我们可以这样写QUERY语句:
Select Customers.Name
FROM Customers
Where Asc([city])=Asc("a");
在这个语句中,我们通过 ASC 返回字符串首字母的ASCII码,然后再进行判断。
如果你希望能够实现类似于LIKE “abc*”的功能,并且希望他是区分大小写的,我们可以这样考虑QUERY语句:
Select Customers.City
FROM Customers
Where (((StrComp([city],"abc",0))=1)) AND (((Asc([city]))>Asc("a") And (Asc([city]))
通过上面的例子您可以看出,虽然我们能够通过变通的方法来实现查询中对于大小写的区分,但是相对来说是比较复杂的,还可能会造成一定性能的影响。并且如果您不能够正确判断所有可能出现的情况的话,查询得到的结果可能会是不正确的(比如,我希望实现LIKE “?a??A*”就非常难以判断了)。
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 统计当月之前(不含当月)的记录...(03.11)
- 【Access Inputbo...(03.03)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)
- 【Access高效办公】上月累...(01.06)
- 【Access Inputbo...(12.23)
- 【Access Dsum示例】...(12.16)

学习心得
最新文章
- 仓库管理实战课程(9)-开发往来单...(04.02)
- 仓库管理实战课程(8)-商品信息功...(04.01)
- 仓库管理实战课程(7)-链接表(03.31)
- 仓库管理实战课程(6)-创建查询(03.29)
- 仓库管理实战课程(5)-字段属性(03.27)
- 设备装配出入库管理系统;基于Acc...(03.24)
- 仓库管理实战课程(4)-建表操作(03.22)
- 仓库管理实战课程(3)-需求设计说...(03.19)
- 仓库管理实战课程(2)-软件背景和...(03.18)
- 仓库管理实战课程(1)-讲师介绍(03.16)