用asp实现多关键字搜索

用asp实现多关键字搜索

在文本框输入多个关键字,中间用空格隔开,然后点击搜索按钮,这样做的目的是什么呢?大家开动一下脑筋,我们是不是在缩小搜索的范围,即搜索出来的结果中既包含“网人”,又包含“ 教程”、“交流”、“图书”这些关键字。当然关键字之间的间隔符不仅可以是空格,还可以是“,”“、”等等,一般来说空格比较方面输入,你说呢!

在书写实现这个 功能的过程中,我们会使用几个非常重要的 asp 函数,先来了解一下:
Split()
函数将一个字符串分割并返回分割结果
表达式 Split (S[,d])

实例
复制内容到剪贴板
代码:
以下为代码部分:
<%
V= Split(A,B,C)
For i = 0 To UBound(V)
Resp****e.Write V(i)
Next
%>

返回结果: A B C

UBound()
函数返回指定数组维数的最大可用下标>.

表达式 Ubound(arrayname [, dimension])

实例:



以下为代码部分:
<%
i = Array("Monday","Tuesday","Wednesday")
resp****e.write UBound(i)
%>

返回结果: 2

Rtrim()

函数去掉字符串右边的字符串.

表达式 Rtrim(string)

LTrim()

函数去掉字符串左边的空格.

表达式 LTrim(string)

REPLACE()

函数REPLACE()是最有用的字符串函数之一。你可以使用REPLACE()函数,以一个字符串取代另一个字符串的一部分。

下面咱们来看看实现的方法和代码:



以下为代码部分:
searchdata=request("T1") '从文本框中获得输入的关键字
if trim(searchdata)="" then '如果没有关键字的输入或者只输入的空格,警告!
resp****e.write "<script>alert('请输入查询搜索关键字!');history.back();</script>"resp****e.end
end if

searchdata=replace(searchdata,"'","’")'将获得的字符串中英文单引号换成中文单引号
searchdata=Rtrim(LTrim(searchdata))'去掉获得的字符串最左边空格和最右边空格

sql1="" '网站关键字匹配sql语句
sql2="" '网站标题匹配sql语句
sql3="" '网站简要说明匹配sql语句

searchdatatmp=split(searchdata," ") '将输入的字符串根据空格分开,获得一个数组
max=ubound(searchdatatmp) '得出这个数组的维数,即输入的关键字个数

if max=0 then '如果max等于0说明只输入了一个关键字,那么就不需要循环处理
sql1=sql1&" key like '%" & searchdatatmp(i) & "%' " '网站关键字模糊搜索
sql2=sql2&" sitename like '%" & searchdatatmp(i) & "%' " '网站标题模糊搜索
sql3=sql3&" faq like '%" & searchdatatmp(i) & "%' " '网站简要说明搜索
else '如果含有多个关键字,采用循环处理sql语句
for i=0 to max '如果关键字很多,我们要求每一个搜索都要匹配每一个关键字,通过循环来实现
if i=0 then '写入下面sql语句作为开头,仔细研究一下下面的代码
sql1=sql1&" (key like '%" & searchdatatmp(i) & "%' and "
sql2=sql2&" (sitename like '%" & searchdatatmp(i) & "%' and "
sql3=sql3&" (faq like '%" & searchdatatmp(i) & "%' and "
else
if i=max then '如果循环到最后一个关键字,写入下面sql语句作为结尾
sql1=sql1&" key like '%" & searchdatatmp(i) & "%') "
sql2=sql2&" sitename like '%" & searchdatatmp(i) & "%') "
sql3=sql3&" faq like '%" & searchdatatmp(i) & "%') "
else '如果关键自己不是开头的也不是结尾的,那么循坏写入下面的sql语句
sql1=sql1&" key like '%" & searchdatatmp(i) & "%' and "
sql2=sql2&" sitename like '%" & searchdatatmp(i) & "%' and "
sql3=sql3&" faq like '%" & searchdatatmp(i) & "%' and "
end if
end if
next '循环结束
end if

sql="select * from www where "&sql1&" or "&sql2&" or "&sql3


resp****e.write sql '看看我们这个代码运行的结果是否正确


在文本框中输入“ASP PHP”,然后点击搜索,记住表单的action="文件名",这个文件里包含以上的代码。
执行结果:

select * from www where (key like '%ASP%' and key like '%PHP%') or
(sitename like '%ASP%' and sitename like '%PHP%') or (faq like '%ASP%' and faq like '%PHP%')
可以看出我们写的代码是正确的了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值