日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

如何用SQL语句实现精确搜索以及模糊搜索

發布時間:2025/3/20 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何用SQL语句实现精确搜索以及模糊搜索 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

在寫WEB項目的時候,搜索是必須提供的功能?
有時候,客戶會輸入用空格或其他分隔符分隔的一組關鍵詞,我們需要根據輸入找出以下結果:?
絕對包含整組關鍵詞連續出現的結果?
包含整組關鍵詞里每個詞條,但是不一定連續出現的結果?
包含整組關鍵詞里任一條或多條關鍵詞的結果?

就像你在GOOGLE里搜索SQL?SERVER?2000,?
它首先嚴格匹配整個字符串?
在找不到的情況下,看有沒有包含這三個單詞的結果?
如果連三個單詞都包含的結果都沒有,就試著找出包含任一個詞的結果?
下面的代碼是用C#在代碼中動態構建這種搜索模式的條件語句的函數?
其中KEYWORD就是關鍵詞了?
SEARCHMODE就是搜索模式了,1代表精確,2,代表全包含?,3代表任意包含?

string?strCondition="Id?in?(";?
????????????string?strSubQuery="select?distinct?productid?from?productcateview?where?id<>0?";?
????????????if(Request.QueryString["Country"]!=null)?
????????????????strSubQuery+="?and?industryRegionId="+Request.QueryString["Country"];?
????????????if(Request.QueryString["Industry"]!=null)?
????????????????strSubQuery+="?and?IndustryId="+Request.QueryString["Industry"];?
????????????if(Request.QueryString["Keyword"]!=null)?
????????????{?????????????????
????????????????//SearchMode:搜索模式,1,代表精確搜索,2代表同時包含搜索3,代表的是包含任一單詞的搜索?
????????????????string?strKeyword=Server.UrlDecode(Request.QueryString["Keyword"].Replace("'","''"));?
????????????????string?strTemp="";?
????????????????strSubQuery+="?and?(";?
????????????????string?[]?KeywordArray;?
????????????????if(strKeyword.IndexOf(',')!=-1)?
????????????????????KeywordArray=strKeyword.Split(',');?
????????????????else?
????????????????????if(strKeyword.IndexOf('|')!=-1)?
????????????????????KeywordArray=strKeyword.Split('|');?
????????????????else?
????????????????????KeywordArray=strKeyword.Split(null);?
????????????????//分主關鍵詞?
????????????????if(KeywordArray.Length<2||strSearchMode=="1")?
????????????????{?
????????????????????strSubQuery+="(?productfullname+'?'+cast(shortdesc?as?varchar)+'?'+keyword+'?'+subcategoryname?like?'%"+strKeyword+"%')";?
????????????????}?
????????????????else?
????????????????{?????
????????????????????if(strSearchMode=="2")?
????????????????????{?
????????????????????????strTemp="productfullname+'?'+cast(shortdesc?as?varchar)+'?'+keyword+'?'+subcategoryname?like?'";?
????????????????????????string?strSqlKeyword="";?
????????????????????????for?(int?i=0;i<KeywordArray.Length;i++)?
????????????????????????{?
????????????????????????????strSqlKeyword+="%"+KeywordArray[i];?
????????????????????????}?
????????????????????????strTemp+=strSqlKeyword+"%'";?
????????????????????}?
????????????????????if(strSearchMode=="3")?
????????????????????{?
????????????????????????strTemp="";?
????????????????????????for?(int?i=0;i<KeywordArray.Length;i++)?
????????????????????????{?
????????????????????????????strTemp+="?productfullname+'?'+cast(shortdesc?as?varchar)+'?'+keyword+'?'+subcategoryname?like?'%"+KeywordArray[i]+"%'?or";?
????????????????????????}?
????????????????????????strTemp=strTemp.TrimEnd(new?char[]?{'o','r'});?
????????????????????}?
????????????????????strSubQuery+=strTemp;?
????????????????}?
????????????????strSubQuery+=")";?
????????????}?
????????????strCondition+=strSubQuery;?
????????????strCondition+=")";?
????????????return(strCondition);?????

三種模式中,第一種會構造出類似下面的SQL條件?
Field1+field2+field3?like?%keyword%?
第二種構造出?
field1+field2+field3?like?%keyword1%keyword2%keyword3%?
第三種構造出?
field1+field2+field3?like?%keyword1%?or?field1+field2+field3?like?%keyword2%?or?field1+field2+field3?like%keyword3%?
這三種模式來?

其中KEYWORD1,KEYWORD2,KEYWORD三就是用KEYWORD分隔出來的單詞了?
一般可以假定客戶用空白字符,OR,|或者,或者;來分隔?
不過,一般來說,客戶總是會用空格來分隔的

轉載于:https://www.cnblogs.com/BoKeRen/archive/2006/03/08/345755.html

總結

以上是生活随笔為你收集整理的如何用SQL语句实现精确搜索以及模糊搜索的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。