欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql中使用sphinx搜索子域名需注意的問(wèn)題

 更新時(shí)間:2013年02月07日 17:32:34   作者:  
比如搜索jb51.net會(huì)把www.dbjr.com.cn、jb51.net、sc.jb51.net等都搜索出來(lái)

搜索子域名

比如搜索jb51.net會(huì)把www.dbjr.com.cn、jb51.net、host.jb51.net等都搜索出來(lái)。

如果使用mysql用like的話效率是非常低的,幾百萬(wàn)甚至上千萬(wàn)的數(shù)據(jù)那是沒(méi)有辦法使用的,于是采取sphinx來(lái)做。

在使用的過(guò)程中發(fā)現(xiàn)了諸多問(wèn)題,這里將其總結(jié)起來(lái),也讓不知道的朋友注意下這些字符。

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

首先如果我們不做任何設(shè)置的話,搜索jb51.net會(huì)出現(xiàn)把a(bǔ)ajb51.net、jb51.a.cn、jb51.net.com(當(dāng)然這個(gè)域名后綴不存在,但是會(huì)有符合相應(yīng)規(guī)則的域名,這里只舉例)等等。

為什么會(huì)出現(xiàn)這種情況呢?

我們使用./search -c 配置文件 -i 索引名 'jb51.net' 搜索的時(shí)候會(huì)發(fā)現(xiàn)下面words部分被分成了兩部分'jb51'和'cn',默認(rèn)以.作為分隔符,如果我們不想讓它做為分隔符,就需要把.添加到charset_table里面,這里需要說(shuō)的是我們搜索域名只需要有字母、數(shù)字、"-"等字符,其他的不需要。設(shè)置如下:
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碼值。
這樣會(huì)解決掉搜出jb51.a.cn這類域名。

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

現(xiàn)在就剩下aajb51.net這類域名,我們使用關(guān)鍵字“ '".jb51.net"' ”(注意是單引號(hào)里面套雙引號(hào))這樣來(lái)搜索,主域名單獨(dú)加上,但是使用的過(guò)程中發(fā)現(xiàn)這樣搜出了與這個(gè)域名無(wú)關(guān)的域名,比如aa.bb.cn這樣,經(jīng)后來(lái)研究是"."的問(wèn)題,后來(lái)把"."替換成"@",來(lái)搜索又出現(xiàn)12306等好多域名無(wú)法讀取到的問(wèn)題,后來(lái)經(jīng)研究估計(jì)這些特殊字符在sphinx中都有特殊的意義,于是找到了"`"這個(gè)字符,換成這個(gè)以后一切才算正常了。

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

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

相關(guān)文章

  • 簡(jiǎn)述MySQL主鍵和外鍵使用及說(shuō)明

    簡(jiǎn)述MySQL主鍵和外鍵使用及說(shuō)明

    MySQL通過(guò)外鍵約束來(lái)保證表與表之間的數(shù)據(jù)的完整性和準(zhǔn)確性,本文主要介紹了簡(jiǎn)述MySQL主鍵和外鍵使用及說(shuō)明,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 如何修改mysql數(shù)據(jù)庫(kù)的max_allowed_packet參數(shù)

    如何修改mysql數(shù)據(jù)庫(kù)的max_allowed_packet參數(shù)

    本篇文章是對(duì)修改mysql數(shù)據(jù)庫(kù)的max_allowed_packet參數(shù)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 華為歐拉openEuler在線安裝MySQL8的實(shí)現(xiàn)步驟

    華為歐拉openEuler在線安裝MySQL8的實(shí)現(xiàn)步驟

    本文主要介紹了華為歐拉openEuler在線安裝MySQL8的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • mysql 5.7.21 解壓版安裝配置圖文教程

    mysql 5.7.21 解壓版安裝配置圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.21 解壓版安裝配置圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • 前端傳參數(shù)進(jìn)行Mybatis調(diào)用mysql存儲(chǔ)過(guò)程執(zhí)行返回值詳解

    前端傳參數(shù)進(jìn)行Mybatis調(diào)用mysql存儲(chǔ)過(guò)程執(zhí)行返回值詳解

    這篇文章主要介紹了前端傳參數(shù)進(jìn)行Mybatis調(diào)用mysql存儲(chǔ)過(guò)程執(zhí)行返回值詳解,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • Mysql數(shù)據(jù)庫(kù)性能優(yōu)化二

    Mysql數(shù)據(jù)庫(kù)性能優(yōu)化二

    這篇文章主要介紹了Mysql數(shù)據(jù)庫(kù)性能優(yōu)化二 的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • MySQL內(nèi)連接和外連接及七種SQL?JOINS的實(shí)現(xiàn)

    MySQL內(nèi)連接和外連接及七種SQL?JOINS的實(shí)現(xiàn)

    這篇文章主要介紹了Mysql內(nèi)連接和外連接的區(qū)別以及七種SQL?Joins的實(shí)現(xiàn),相信看完這篇文章你對(duì)SQL內(nèi)外連接的多表查詢就足夠理解了,需要的朋友可以參考下
    2023-03-03
  • mysql創(chuàng)建表添加字段注釋的實(shí)現(xiàn)方法

    mysql創(chuàng)建表添加字段注釋的實(shí)現(xiàn)方法

    這篇文章主要介紹了mysql創(chuàng)建表添加字段注釋的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • MySQL執(zhí)行SQL語(yǔ)句的流程詳解

    MySQL執(zhí)行SQL語(yǔ)句的流程詳解

    這篇文章主要介紹了MySQL執(zhí)行SQL語(yǔ)句的流程詳解,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • MySQL聚合查詢與聯(lián)合查詢操作實(shí)例

    MySQL聚合查詢與聯(lián)合查詢操作實(shí)例

    這篇文章主要給大家介紹了關(guān)于MySQL聚合查詢與聯(lián)合查詢操作的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-02-02

最新評(píng)論