上一篇:在ADO使用SELECT语法三 >>
ADO使用SELECT语法二
WHERE可以使用下面的BETWEEN、LIKE、IN运算子。
Between...And
Between...And判断表达式的值是否落在指定的范围之中。语法为:
expr Between value1 And value2
表示如果expr的值介于value1和value2之间,则Between...And运算子会返回True;否则它会返回False。
您也可以加上逻辑运算 Not expr Between value1 And value2,来判断相反的条件,即expr落在value1和 value 2的范围之外。
如果expr、value1、或value2为Null时,则Between...And会返回Null值。
您不能在 Between...And 运算子中使用通配符*,例如,您不能使用 100* 和 500* 来寻找介于1000至5000中的产品代号。
Like
Like寻找相符合的关键字。
Like跟随一个运算式,列出所要比较的字串或字符串文字。
在一运算式中,您可以使用 Like 运算子将一字段资料和一字串运算式做一比较。您可以使用通配符*来找出相类似的资料,譬如Like "王*",则查询会返回所有字段中以 [王] 做为开头的资料。
Like后运算式可以使用的符号:
%:通配符,表示一个或多个字符,譬如LIKE jack% 将找到所有以jack为起头的字串文字,LIKE %jack%则找到包括jack的字串文字。
_:一个字符的通配符,譬如LIKE jack_ 将找到如jack1、jacka等字串文字,LIKE _jack_ 则找到如ajackb、cjackf等字串文字。
[x-y]:指定字符范围,譬如LIKE [a-c]jack 将找到如ajack1、bjack、cjack等字串文字。
[^x-y]:指定排除的字符范围,譬如LIKE [^a-c]jack 将不会找到如ajack1、bjack、cjack等字串文字。
下例中,会得到以字母A做为开头而其后接着介于B到G之间的任何字母和一个数字的资料:
Like "A[B-G]#"
IN
IN运算式,限定范围。
语法为:
expr [Not] In(value1, value2,…)
其中expr为运算式字段。value1, value2, …为指定的范围清单。
例如,您可以使用In运算子,来指定学生必须居住的城市,为广州市、深圳市、或汕头市:
SELECT *
FROM 学生
WHERE 城市 In (@#广州市@#,@#深圳市@#,@#汕头市@#)
让我们看一个ASP程式使用这个SQL指令的例子。
我们可以利用IN子句决定范围,譬如ASP程式rs24.asp如下,[SELECT 姓名,科目,分数 From 考试 Where 分数 In (SELECT 分数 From 考试 Where 分数>=60)],使用IN找出分数大于或等于60分的记录:
<%
Set conn1 = Server.CreateObject("ADODB.Connection")
conn1.Open "DBQ=" & Server.MapPath("ntopsamp.mdb") & ";Driver={Microsoft Access Driver (*.mdb)};DriverId=25;FIL=MS Access;"
Set rs2 = Server.CreateObject("ADODB.Recordset")
SqlStr = "SELECT 姓名,科目,分数 From 考试 Where 分数 In (SELECT 分数 From 考试 Where 分数>=60)"
rs2.Open SqlStr,conn1,1,1
Response.Write "<p>In: 低于60分不算"
Do while not rs2.EOF
Response.Write "<BR>" & rs2("姓名") & " " & rs2("科目") & " 分数: " & rs2("分数")
rs2.MoveNext
Loop
rs2.Close
%>
以上的ASP程式rs24.asp,在用户端使用浏览器,浏览执行的结果,显示分数大于或等于60分的记录。
NOT IN
NOT IN运算式,表示不属于所指定的范围。
让我们看一个于ASP程式中使用这个SQL指令的例子。
我们可以利用Not In子句决定不应显示的记录,譬如ASP程式rs24.asp如下,[SELECT 姓名,科目,分数 From 考试 Where 分数 Not In (SELECT 分数 From 考试 Where 分数>=60)],使用IN找出分数不大于或等于60分的记录,即小于60分的记录:
<%
Set conn1 = Server.CreateObject("ADODB.Connection")
conn1.Open "DBQ=" & Server.MapPath("ntopsamp.mdb") & ";Driver={Microsoft Access Driver (*.mdb)};DriverId=25;FIL=MS Access;"
Set rs2 = Server.CreateObject("ADODB.Recordset")
SqlStr = "SELECT 姓名,科目,分数 From 考试 Where 分数 Not In (SELECT 分数 From 考试 Where 分数>=60)"
rs2.Open SqlStr,conn1,1,1
Response.Write "<p>Not In: 高于60分不算"
Do while not rs2.EOF
Response.Write "<BR>" & rs2("姓名") & " " & rs2("科目") & " 分数: " & rs2("分数")
rs2.MoveNext
Loop
rs2.Close
%>
以上的 ASP程式rs24.asp,在用户端使用浏览器,浏览执行的结果,显示分数不大于或等于60分的记录
下一篇:在ADO使用SELECT语法一 >>
相关文章:
- · 解决在执行数据库查询中的特殊字符的问题
- · asp分页显示详论
- · ASP编写数据库维护程序
- · Session对象在各浏览器中的有效范围
- · ASP访问Exchange Server问题
- · 用FrontPage98 开 发ASP
- · Global.asa 参考(五) - TypeLibrary 声明
- · Global.asa 参考(三) - <OBJECT> 声明
- · Global.asa 参考(三) - Session 事件
- · Global.asa 参考(二) - Application 事件
- · Global.asa 参考(一) - 总述
- · ADO如何使用Delete语法
- · 测试客户端屏幕状况
- · 使用隐藏form把数据从客户端传到服务端
- · 用GetString来提高ASP的速度
- · ADO如何使用Update语法
- · ASP的几大可扩展组件(一)
- · 在VBSript中使用regular expression取得子字串
- · Developing ASP-Based Applications
- · ASP缓存技术
- · ASP注册表项目修改
- · ASP和SQL结合处理时间小解
- · ASP实现多语言支持
- · 用ASP实现号码转换
- · 用ASP进行网络打印功能
- · 用ASP发送邮件
- · 一个让用户更改密码的简单程序!
- · 在ASP中用集合成批操作数据库
- · ASP检索网站指定目录文件的算法与应用方向
- · 网页计数器的程序
- · 好东西,翻页程序,大家可以参考
- · Recordset对象方法详解
- · 不用数据源打开数据库(DSNless connection)
- · 处理二进制数据
- · 利 用 ISAPI 实 现 向 数 据 库 中 添 加 记 录 (六)
- · 利 用 ISAPI 实 现 向 数 据 库 中 添 加 记 录 (五)
- · 利 用 ISAPI 实 现 向 数 据 库 中 添 加 记 录 (四)
- · 利 用 ISAPI 实 现 向 数 据 库 中 添 加 记 录 (三)
