《Mysql應用mysql中使用sphinx搜索子域名需注意的問題》要點:
本文介紹了Mysql應用mysql中使用sphinx搜索子域名需注意的問題,希望對您有用。如果有疑問,可以聯系我們。
搜索子域名MYSQL數據庫
好比搜索jb51.net會把www.jb51.net、jb51.net、host.jb51.net等都搜索出來.MYSQL數據庫
如果使用mysql用like的話效率是非常低的,幾百萬甚至上千萬的數據那是沒有方法使用的,于是采取sphinx來做.MYSQL數據庫
在使用的過程中發現了諸多問題,這里將其總結起來,也讓不知道的朋友注意下這些字符.MYSQL數據庫
分析:
sphinx是全文索引,它搜索的是包括的記錄.MYSQL數據庫
首先如果我們不做任何設置的話,搜索jb51.net會出現把aajb51.net、jb51.a.cn、jb51.net.com(當然這個域名后綴不存在,但是會有符合相應規則的域名,這里只舉例)等等.MYSQL數據庫
為什么會出現這種情況呢?MYSQL數據庫
我們使用./search -c 配置文件 -i 索引名 'jb51.net' 搜索的時候會發現下面words部分被分成了兩部分'jb51'和'cn',默認以.作為分隔符,如果我們不想讓它做為分隔符,就需要把.添加到charset_table里面,這里需要說的是我們搜索域名只需要有字母、數字、"-"等字符,其他的不需要.設置如下:
charset_table = 0..9,A..Z->a..z, a..z,U+002e,U+002d,U+0040,U+0060? #其中U+002e代表".",U+002d代表"-",U+0040代表"@",U+0060代表"`",這里為ascii碼值.
這樣會辦理掉搜出jb51.a.cn這類域名.MYSQL數據庫
那么jb51.net.com這類呢?我們可以在索引的字段中增加惟一后綴好比“XXXXX”,concat(search,'XXXXX')這樣,就不會出來了.MYSQL數據庫
現在就剩下aajb51.net這類域名,我們使用關鍵字“ '".jb51.net"' ”(注意是單引號里面套雙引號)這樣來搜索,主域名單獨加上,但是使用的過程中發現這樣搜出了與這個域名無關的域名,好比aa.bb.cn這樣,經后來研究是"."的問題,后來把"."替換成"@",來搜索又出現12306等好多域名無法讀取到的問題,后來經研究估計這些特殊字符在sphinx中都有特殊的意義,于是找到了"`"這個字符,換成這個以后一切才算正常了.MYSQL數據庫
注意:將"."替換成"`"等相應字符后需在charset_table里增加這個字符,不然是被忽略的.MYSQL數據庫
所以在搜索的過程中我們必要注意下這些特殊字符.MYSQL數據庫
維易PHP培訓學院每天發布《Mysql應用mysql中使用sphinx搜索子域名需注意的問題》等實戰技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養人才。