您现在的位置: 万盛学电脑网 >> 程序编程 >> 数据库 >> access教程 >> access基础教程 >> 正文

Access教程:查询文本时,如何匹配大小写

作者:佚名    责任编辑:admin    更新时间:2022-06-22

Access教程:查询文本时,如何匹配大小写


我们看看下面的例子:
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]))<Asc("c")));
   
通过上面的例子您可以看出,虽然我们能够通过变通的方法来实现查询中对于大小写的区分,但是相对来说是比较复杂的,还可能会造成一定性能的影响。并且如果您不能够正确判断所有可能出现的情况的话,查询得到的结果可能会是不正确的(比如,我希望实现LIKE “?a??A*”就非常难以判断了);