| 導購 | 订阅 | 在线投稿
分享
 
 
 

中文分詞搜索,asp拆詞搜索,asp智能分詞搜索

來源:互聯網  2008-06-01 03:08:06  評論

在做一個網站時,老板讓實現像百度那樣的搜索功能,以前asp實現的都是模糊搜索,匹配查詢。沒辦法。到網上搜搜看,我發現網上提供的方法有這幾種,一是建個詞庫,二是用分詞組件,三就是我說的這種,自動分詞技術,不過也不是智能的分詞,只是隔兩個詞匹配。最好的是建個詞庫,根據用戶的輸入來擴充詞庫,但對于中小型網站,這可能不太需要。

這是我說的第三種分詞搜索,代碼如下:使用方法就不說了。

<%

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

%>

在做一個網站時,老板讓實現像百度那樣的搜索功能,以前asp實現的都是模糊搜索,匹配查詢。沒辦法。到網上搜搜看,我發現網上提供的方法有這幾種,一是建個詞庫,二是用分詞組件,三就是我說的這種,自動分詞技術,不過也不是智能的分詞,只是隔兩個詞匹配。最好的是建個詞庫,根據用戶的輸入來擴充詞庫,但對于中小型網站,這可能不太需要。 這是我說的第三種分詞搜索,代碼如下:使用方法就不說了。 <% 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 %>
󰈣󰈤
王朝萬家燈火計劃
期待原創作者加盟
 
 
 
>>返回首頁<<
 
 
 
 
 熱帖排行
 
 
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有