学院首页 软件应用 编程开发 创意设计 认证培训 软件论坛
ASP ASP.NET PHP JSP SQL MYSQL Java VB

您的位置:学院 >> 编程开发 >> ASP >> 在ASP应用程序中加入智能搜索


在ASP应用程序中加入智能搜索


第一步,我们要建立一个名为db_sample.mdb的数据库(本文以Access2000数据库为例),并在其中建立表T_Sample。表T_Sample包括如下字段:

  ID 自动编号
  U_Name 文本
  U_Info 备注

  第二步,我们开始设计搜索页面Search.asp。该页面包括一个表单(Frm_Search),表单内包括一个文本框和一个提交按钮。并将表单的method属性设为“get” ,action属性设为“Search.asp",即提交给网页自身。代码如下:

<!-- Search.asp -->
<form name="frm_Search" method="get" action="Search.asp">
请输入关键字:
<input type="text" name="key" size="10">
<input type="submit" value="搜索">
</form>

  下面,就进入了实现智能搜索的关键部分。

  首先,建立数据库连接。在Search.asp的开始处加入如下代码:

<%
 Dim strProvider,CNN
 strProvider="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="
 strProvider=strProvider & Server.MapPath("\") & "\data\db_Sample.mdb" 假设数据库存放在主页根目录下的data目录下
 Set CNN = Server.CreateObject("ADODB.connection")
 CNN.Open strProvider 打开数据库连接
%>

  接下来,判断 ASP页所接收到的数据,并在数据库中进行搜索。

<%
 Dim S_Key,RST,StrSQL
 S_Key = Trim(Request("key")) 得到搜索关键字的值
 If S_Key <>"" then
  Set RST=Server.CreateObject("ADODB.RecordSet")
  StrSQL=AutoKey(S_Key) 此处使用自定义函数 AutoKey(),该函数为实现智能搜索的核心
  RST.Open StrSQL,CNN,3,2 得到搜索后的记录
  If RST.BOF And RST.EOF Then
%>
<font color="#FF0000">未找到任何结果!!!</font>
<%
Else
%>
搜索名称为“<font color="#FF0000"><%= S_Key %></font>”的项,共找到 <font color="#FF0000"><%= RST.RecordCount %></font> 项:<p>
<%
While Not RST.EOF 遍历整个记录集,显示搜索到的信息并设置链接
%>
<!-- 此处可设为你所需要的链接目标 -->
<font style="font: 12pt 宋体"><a href="info.asp?ID=<%= RST("ID") %>" target="_blank"><%= RST("U_Name") %></a></font>

<!-- 显示部分详细内容 -->
<font style="font: 9pt 宋体"><%= Left(RST("U_Info"),150) %></font><p>
<%
 RST.MoveNext
 Wend
  RST.Close
  Set RST=Nothing
 End If
End If
%>

  在上面的代码中,有一个自定义函数 AutoKey ,该函数是实现智能搜索的核心所在。代码如下:

<%
Function AutoKey(strKey)
CONST lngSubKey=2
Dim lngLenKey, strNew1, strNew2, i, strSubKey

  检测字符串的合法性,若不合法则转到出错页。出错页你可以根据需要进行设定。

if InStr(strKey,"=")<>0 or InStr(strKey,"`")<>0 or InStr(strKey,"")<>0 or InStr(strKey," ")<>0 or InStr(strKey," ")<>0 or InStr(strKey,"")<>0 or InStr(strKey,chr(34))<>0 or InStr(strKey,"\")<>0 or InStr(strKey,",")<>0 or InStr(strKey,"<")<>0 or InStr(strKey,">")<>0 then
Response.Redirect "error.htm"
End If

lngLenKey=Len(strKey)
Select Case lngLenKey
Case 0 若为空串,转到出错页
Response.Redirect "error.htm"
Case 1 若长度为1,则不设任何值
strNew1=""
strNew2=""
Case Else 若长度大于1,则从字符串首字符开始,循环取长度为2的子字符串作为查询条件
For i=1 To lngLenKey-(lngSubKey-1)
strSubKey=Mid(strKey,i,lngSubKey)
strNew1=strNew1 & " or U_Name like %" & strSubKey & "%"
strNew2=strNew2 & " or U_Info like %" & strSubKey & "%"
Next
End Select

  得到完整的SQL语句

AutoKey="Select * from T_Sample where U_Name like %" & strKey & "% or U_Info like %" & strKey & "%" & strNew1 & strNew2

End Function
%>

  要实现智能搜索,其核心就是将搜索关键字进行自动分组。在此处,我们使用了循环取长度为2的子串的方法。为什么不将子串长度定为1、3、4或其他呢?这是因为若子串长度小于2即为1时,会失去将关键字分组的功能,而若子串长度大于2,则会丢失一些词组。大家可以将 CONST lngSubKey=2改为其他数字试一试,孰优孰劣自见分晓。

  最后,别忘了将数据连接关闭,以释放资源。

<%
CNN.Close
Set CNN=Nothing
%>

  至此,这个智能搜索引擎已经完成了。你还可以将其继续完善,比如添加分页、突出显示等功能。好了,不耽误大家时间了,赶快去试一试吧。
技术文章快速查找

栏目导航
软件应用
·操作系统 ·杀毒防黑 ·应用软件
·聊天软件 ·网络软件  
Web开发
·ASP ·JavaScript ·CGI
·JSP ·VbScript ·Web服务器
·PHP ·XML  
开发语言
·VB ·VC ·ASP.NET
·Java ·C/C++ ·Delphi
数据库开发
·MySQL ·SQL/Access ·PowerBuilder
·Oracle ·DB2  
网站设计
·Flash ·Dreamweaver ·HTML/CSS
·Fireworks ·FrontPage  
平面设计
·Photoshop ·CorelDraw ·AutoCAD
·FreeHand ·Illustrator ·3DsMAX
媒体动画
·Director ·Authorware ·Maya
·视频处理    


相关软件 产品库推荐
·笔记本 ·台式机 ·服务器
·数码相机 ·手机 ·GPS
·DV摄像机 ·MP3 ·MP4
·CPU ·硬盘 ·内存
·主板 ·显卡 ·显示器
·打印机 ·投影机 ·路由器

还没人留言,抢个先,哈哈!
对"在ASP应用程序中加入智能搜索"的评论 - 快速回贴
内容:
  [完成后可按Ctrl+Enter发布]

百度中 在ASP应用程序中加入智能搜索 相关内容
Google搜索中 在ASP应用程序中加入智能搜索 相关内容
雅虎中 在ASP应用程序中加入智能搜索 相关内容
Sogou搜索中 在ASP应用程序中加入智能搜索 相关内容

相关软件 最新回复帖子:

·Windows Vista 中卸载软件的不同方式
·没有mysql支持时的替代方案
·一个可以发送附件及HTML格式邮件的PHP类
·AutoCAD打造精致三维鸟笼实例详解
·Photoshop自定义水晶字特效样式
·AutoCAD三维基础实例教程
·PS为黑背景长发美女照片抠图换背
·用Photoshop自制个性摩托车贴花小经验
·轻松几步将美女照片处理为手工素描
·巧用Photoshop画笔轻松绘制创意特效


  相关软件 在ASP应用程序中加入智能搜索相关文章
ASP无组件上传进度条解决方案 ASP中实现分页显示的七种武器
ASP开发中数据库文件调用的捷径 巧用缓存提高ASP应用程序的性能
SQL注入天书之ASP注入漏洞全接触 ASP中也能解压缩rar文件
浅谈ASP中Web页面间的数据传递 用ASP设计收发文管理系统
ASP万用分页程序 用ASP编写网站流量统计系统
ASP数据库编程SQL常用技巧 加速ASP程序的显示速度
浅析ASP内置组件 ASP+SQL Server构建网页防火墙
ASP整合的一个SQL语句类 利用ASP打造网站论坛DIY
ASP中使用Office2000中的图表控件 ASP编程中15个非常有用的例子
在ASP中使用Oracle数据库 对ASP脚本源代码进行加密