在ADO使用SELECT语法二
程序员文章站
2022-07-10 12:30:35
接上一篇文章:
where可以使用下面的between、like、in运算子。
between...and
between...and判断表达式的值是否落在指定的范围之中。语法为:
expr...
接上一篇文章:
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.如下,[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分的记录
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.如下,[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分的记录
推荐阅读