比較不錯(cuò)的asp單表單字段多條件查詢
更新時(shí)間:2007年09月27日 18:48:12 作者:
用途:文章表內(nèi)文章關(guān)鍵字查詢
查詢格式: 百度 google 百度好還是google好 百度+google?。ㄒ部刹惠斎霔l件全部查詢)
<!--#include file="conn.asp"-->
<%
Function SearshSQL(Tname,Lname,Str) 'Tname-表名 Lname-列名 Str-查詢的字符
If Trim(Str)="" then
MySql="Select * From "&Tname
Else
Str=SqlEncode(Str) '預(yù)處理查詢字符串
ArrStr=split(Str," ") '用空格分割處理后字符串
Umax=Ubound(ArrStr) '分割后數(shù)組上維,確定分割成關(guān)鍵詞的個(gè)數(shù)
If Umax>0 Then '關(guān)鍵詞中多個(gè)空格的處理,從第2維開(kāi)始處理
For i=1 to Umax
StrTemp=ArrStr(i)
If Trim(StrTemp)="" Then StrTemp="/~~~~~/" '分割成的元素為空用特殊字符代替
Sql=Sql &" Or "& Lname &" like '%"& StrTemp &"%'"
Next
End If
MySql="Select * From "& Tname &" where "& Lname &" like '%"&ArrStr(0)&"%'"&Sql
Do
j=InStr(1,MySql, "%/~~~~~/%",1)
If j=0 Then
Exit Do
End If
MySql=Replace(MySql," Or "&Lname&" like '%/~~~~~/%'","")
Loop
End IF
SearshSQL=MySql
end function
Function SqlEncode(Str) '格式化字符串
str=replace(str," "," ") '先把左右的全角空格替換成半角空格
str=trim(str)
str=replace(str,"["," ")
str=replace(str,"';"," ")
str=replace(str,"'"," ")
str=replace(str,"_"," ")
str=replace(str,"%"," ")
str=replace(str,"+"," ")
str=replace(str," "," ")
sqlencode=str
end function
%>
<%
sql=SearshSQL("article","coments","蘿卜+白菜 狗熊") +"order by..(排序)"
Set rs=Server.Createobject("ADODB.RECORDSET")
rs.Open sql,conn,1,1
if not rs.eof then
下面的自己寫(xiě)
查詢格式: 百度 google 百度好還是google好 百度+google?。ㄒ部刹惠斎霔l件全部查詢)
<!--#include file="conn.asp"-->
<%
Function SearshSQL(Tname,Lname,Str) 'Tname-表名 Lname-列名 Str-查詢的字符
If Trim(Str)="" then
MySql="Select * From "&Tname
Else
Str=SqlEncode(Str) '預(yù)處理查詢字符串
ArrStr=split(Str," ") '用空格分割處理后字符串
Umax=Ubound(ArrStr) '分割后數(shù)組上維,確定分割成關(guān)鍵詞的個(gè)數(shù)
If Umax>0 Then '關(guān)鍵詞中多個(gè)空格的處理,從第2維開(kāi)始處理
For i=1 to Umax
StrTemp=ArrStr(i)
If Trim(StrTemp)="" Then StrTemp="/~~~~~/" '分割成的元素為空用特殊字符代替
Sql=Sql &" Or "& Lname &" like '%"& StrTemp &"%'"
Next
End If
MySql="Select * From "& Tname &" where "& Lname &" like '%"&ArrStr(0)&"%'"&Sql
Do
j=InStr(1,MySql, "%/~~~~~/%",1)
If j=0 Then
Exit Do
End If
MySql=Replace(MySql," Or "&Lname&" like '%/~~~~~/%'","")
Loop
End IF
SearshSQL=MySql
end function
Function SqlEncode(Str) '格式化字符串
str=replace(str," "," ") '先把左右的全角空格替換成半角空格
str=trim(str)
str=replace(str,"["," ")
str=replace(str,"';"," ")
str=replace(str,"'"," ")
str=replace(str,"_"," ")
str=replace(str,"%"," ")
str=replace(str,"+"," ")
str=replace(str," "," ")
sqlencode=str
end function
%>
<%
sql=SearshSQL("article","coments","蘿卜+白菜 狗熊") +"order by..(排序)"
Set rs=Server.Createobject("ADODB.RECORDSET")
rs.Open sql,conn,1,1
if not rs.eof then
下面的自己寫(xiě)
相關(guān)文章
ASP在ACCESS中模糊查詢"內(nèi)存溢出"的解決方法
這篇文章主要介紹了ASP在ACCESS中模糊查詢"內(nèi)存溢出"的解決方法,本文導(dǎo)致這個(gè)問(wèn)題的原因是字符編碼問(wèn)題,使用了一個(gè)轉(zhuǎn)碼函數(shù)解決,需要的朋友可以參考下2014-06-06ASP上傳漏洞之利用CHR(0)繞過(guò)擴(kuò)展名檢測(cè)腳本
本文部分腳本具有攻擊性,僅供學(xué)習(xí)研究用,請(qǐng)用在合法合理范圍內(nèi),對(duì)造成的損失本人不承擔(dān)責(zé)任,本人也不提供黑客攻擊技術(shù)指導(dǎo)2012-01-01對(duì)于ASP編碼問(wèn)題的深入研究與最終解決方案
對(duì)于ASP編碼問(wèn)題的深入研究與最終解決方案...2007-05-05asp 實(shí)現(xiàn)顯示所有的服務(wù)器變量值的函數(shù)
asp 實(shí)現(xiàn)顯示所有的服務(wù)器變量值的函數(shù)...2007-08-08比較詳細(xì)的Asp偽靜態(tài)化方法及Asp靜態(tài)化探討
本站已經(jīng)收藏了不少關(guān)于偽靜態(tài)的文章,這篇文章本站已經(jīng)有了,但主要考慮比較詳細(xì),大家可以參考下2008-08-08