网络编程
位置:首页>> 网络编程>> Asp编程>> 基于ASP的站内多值搜索(2)

基于ASP的站内多值搜索(2)

 来源:CSDN 发布时间:2010-05-11 20:03:00 

标签:搜索,asp
 


再来看看递进法,与枚举法相比它们只有核心部分不同:


























'递进法的搜索核心,依次判断条件为空否,非空则将其加入搜索条件 
sql="select * from address where" 
if Name<>"" then 
sql=sql&" Name like '%"&Name&"%' " 
  flag=1 
end if 
if Tel<>"" and flag=1 then 
sql=sql&" and Tel like '%"&Tel&"%'" 
flag=1 
elseif Tel<>"" then 
sql=sql&" Tel like '%"&Tel&"%'" 
flag=1 
end if 
if Company<>"" and flag=1 then 
sql=sql&" and Company like '%"&Company&"%'" 
flag=1 
elseif Company <>"" then 
sql=sql&" Company like '%"&Company&"%'" 
flag=1 
end if 
if flag=0 then 
   sql="select * from address order by ID asc" 
end if 
rs.open sql,conn,1,1


递进法是一个明智的算法,单从语句的长短就可以看出来了。这个算法的难点和精髓就在flag和&上。首先你应该清楚&在SQL中就是一个字符串连接符,把该符号左右的字符拼接在一起。再回到程序,当Name不为空时sql="select * from address where Name like '%"&Name&"%' "同时flag=1;接下来当Name不为空时且Tel不为空时,即Tel<>"" and flag=1时,sql="select * from address where Name like '%"&Name&"%' and Tel like '%"&Tel&"%' "同时flag=1,否则当Name为空Tel不为空,sql="select * from address where Tel like '%"&Tel&"%' "同时flag=1;以此类推就可以推广到n个条件的搜索。当然条件皆为空时,即flag=0将选择所有表中所有项。

3.验证:
至此,一个搜索引擎就建立起来了。以下是一些使用示例:


姓名:张

电话:

学校:

搜索按钮


 

搜索结果为:
姓名: 张三 电话:33333333 单位:电子科技大学计算机系


 



姓名:

电话:

学校:大学

搜索按钮


 


搜索结果为:


姓名:张三 电话:33333333 单位:电子科技大学计算机系


姓名  李 四 电话:44444444 单位:四川大学生物系


姓名:王二 电话:22222222 单位:西南交通大学建筑系



姓名:

电话:4444

学校:四川

搜索按钮


 


搜索结果为:


姓名  李 四 电话:44444444 单位:四川大学生物系



姓名:

电话:

学校:交%大

搜索按钮


 


搜索结果为:


姓名:王二 电话:22222222 单位:西南交通大学建筑系


4.改进:
其实这个引擎还有些缺陷,问题主要在于通配符%。一方面是因为人们平时习惯把*作为通配符,另一方面%若出现在超链接中,通过request获取时%将被“吃”掉,如下:
--test.htm--
…    
<a href=test.asp?content=test%the%sign>click here</a>

--test.asp--

<%
content=request(“content”)
response.write content
%>
在IE中浏览test.htm时点击超链接,显示为:
testthesign
可见%直接被超链接忽略掉了。怎么才能解决这个问题呢?很简单,我们做点小小的手脚--偷梁换柱。
将以下代码加在搜索核心之前:
Name=replace(Name,"*","%")
Tel=replace(Tel,"*","%")
Company=replace(Company,"*","%")
将以下代码加在搜索核心之后:
Name=replace(Name,"%","*")
Tel=replace(Tel,"%","*")
Company=replace(Company,"%","*")
在我们来分析一下这些语句。replace()是VB中字符串替换函数,replace(Name,"*","%") 就是将Name中所有的*换成%。也就是说,我们把3个条件中凡是出现的*都替换为%,这样一来前3句就将通配符改成*了。而后3句就可以防止%被“吃”掉。所有问题就迎刃而解了吧。



姓名:

电话:

学校:交%大

搜索按钮



搜索结果为:
姓名:王 二 电话:22222222 单位:西南交通大学建筑系
将上面的语句再改一改,把*用空格代替,不就成了我们在Google、BaiDu中常用的用空格来分开搜索条件的搜索引擎了吗?

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com