国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

mysql中使用sphinx搜索子域名需注意的問題

2024-07-24 12:48:44
字體:
來源:轉載
供稿:網友

搜索子域名

比如搜索Vevb.com會把www.survivalescaperooms.com、Vevb.com、host.Vevb.com等都搜索出來。

如果使用mysql用like的話效率是非常低的,幾百萬甚至上千萬的數據那是沒有辦法使用的,于是采取sphinx來做。

在使用的過程中發現了諸多問題,這里將其總結起來,也讓不知道的朋友注意下這些字符。

分析:
sphinx是全文索引,它搜索的是包含的記錄。

首先如果我們不做任何設置的話,搜索Vevb.com會出現把aaVevb.com、jb51.a.cn、Vevb.com.com(當然這個域名后綴不存在,但是會有符合相應規則的域名,這里只舉例)等等。

為什么會出現這種情況呢?

我們使用./search -c 配置文件 -i 索引名 'Vevb.com' 搜索的時候會發現下面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這類域名。

那么Vevb.com.com這類呢?我們可以在索引的字段中增加惟一后綴比如“XXXXX”,concat(search,'XXXXX')這樣,就不會出來了。

現在就剩下aaVevb.com這類域名,我們使用關鍵字“ '".Vevb.com"' ”(注意是單引號里面套雙引號)這樣來搜索,主域名單獨加上,但是使用的過程中發現這樣搜出了與這個域名無關的域名,比如aa.bb.cn這樣,經后來研究是"."的問題,后來把"."替換成"@",來搜索又出現12306等好多域名無法讀取到的問題,后來經研究估計這些特殊字符在sphinx中都有特殊的意義,于是找到了"`"這個字符,換成這個以后一切才算正常了。

注意:將"."替換成"`"等相應字符后需在charset_table里增加這個字符,不然是被忽略的。

所以在搜索的過程中我們需要注意下這些特殊字符。

您可能感興趣的文章:

Mysql全文搜索match against的用法mysql 模糊搜索的方法介紹Mysql Binlog快速遍歷搜索記錄及binlog數據查看的方法mysql全文搜索 sql命令的寫法mysql 搜索之簡單應用php利用scws實現mysql全文搜索功能的方法php mysql like 實現多關鍵詞搜索的方法詳細介紹基于MySQL的搜索引擎MySQL-Fullltextmysql 全文搜索 技巧MySQL多層級結構-樹搜索介紹在MySQL中使用Sphinx實現多線程搜索的方法MySQL高效模糊搜索之內置函數locate instr position find_in_set使用詳解
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 泰兴市| 屯留县| 仙桃市| 张家界市| 黄龙县| 平谷区| 绥化市| 页游| 六盘水市| 孝义市| 綦江县| 中超| 宁强县| 广州市| 合山市| 内江市| 宁明县| 德化县| 苏州市| 凤冈县| 承德县| 广饶县| 孟村| 洪湖市| 延边| 佛教| 泸水县| 酒泉市| 扎兰屯市| 泽州县| 玛沁县| 准格尔旗| 景宁| 开封市| 军事| 宜城市| 安岳县| 宁蒗| 东丰县| 德化县| 余姚市|