深入解析php之sphinx
<?php
//參數(shù)篩選
//篩選cat_id=2
$cl->SetFilter("cat_id",array(2));
//僅在id為1、3、7的子論壇中搜索
$cl->SetFilter("forum_id",array(1,3,7));
//范圍篩選
//篩選發(fā)布時(shí)間為今天,參數(shù)為int時(shí)間戳
$cl->SetFilterRange("starttime",123,124);
//篩選價(jià)格
$cl->SetFilterRange("price",10.0,99.9);
// 分組
//按照item_id分組,并且按照order desc排序
$cl->SetGroupBy("item_id",SPH_GROUP_ATTR,"order desc");
//排序模式
//按照price desc排序
$cl->SetSortMode(SPH_SORT_ATTR_DESC,"price");
注意:會(huì)被SetGroupBy中的排序覆蓋
// 匹配查詢?cè)~中的任意一個(gè)
$cl->SetMatchMode ( SPH_MATCH_ANY );
SPH_MATCH_ALL, 匹配所有查詢?cè)~(默認(rèn)模式);
SPH_MATCH_ANY, 匹配查詢?cè)~中的任意一個(gè);
SPH_MATCH_PHRASE, 將整個(gè)查詢看作一個(gè)詞組,要求按順序完整匹配;
SPH_MATCH_BOOLEAN, 將查詢看作一個(gè)布爾表達(dá)式 (參見(jiàn) 第 5.2 節(jié) “布爾查詢語(yǔ)法”);
SPH_MATCH_EXTENDED, 將查詢看作一個(gè)CoreSeek/Sphinx內(nèi)部查詢語(yǔ)言的表達(dá)式 (參見(jiàn) 第 5.3 節(jié) “擴(kuò)展查詢語(yǔ)法”). 從版本Coreseek 3/Sphinx 0.9.9開(kāi)始, 這個(gè)選項(xiàng)被選項(xiàng)SPH_MATCH_EXTENDED2代替,它提供了更多功能和更佳的性能。保留這個(gè)選項(xiàng)是為了與遺留的舊代碼兼容——這樣即使 Sphinx及其組件包括API升級(jí)的時(shí)候,舊的應(yīng)用程序代碼還能夠繼續(xù)工作。
SPH_MATCH_EXTENDED2, 使用第二版的“擴(kuò)展匹配模式”對(duì)查詢進(jìn)行匹配.
SPH_MATCH_FULLSCAN, 強(qiáng)制使用下文所述的“完整掃描”模式來(lái)對(duì)查詢進(jìn)行匹配。注意,在此模式下,所有的查詢?cè)~都被忽略,盡管過(guò)濾器、過(guò)濾器范圍以及分組仍然起作用,但任何文本匹配都不會(huì)發(fā)生.
//從0開(kāi)始查詢,查詢30條,返回結(jié)果最多為1000
$cl->setLimits(0,30,1000);
// 從名稱為index的sphinx索引查詢“電影票”
$cl->Query("電影票","index");
// 從名稱為index的sphinx索引查詢“電影票”
$sp->SetGroupBy('item_id',SPH_GROUP_ATTR,'s_order desc');
$sp->SetFilter('city_id','1');
$sp->SetFilter('cat_id',array(1));
$sp->SetLimit(0,10,1000);
$sp->AddQuery('電影票','index');
$sp->ResetFilters();//重置篩選條件
$sp->ResetGroupBy();//重置分組
$sp->SetGroupBy('item_id', SPH_GROUPBY_ATTR, 's_order desc');
$sp->setFilter('city_id', '2');
$sp->setFilter('cat_id', array(2));
$sp->setLimits(0, 20, 1000);
$sp->AddQuery('溫泉', 'index');
$sp->ResetFilters();// 重置篩選條件
$sp->ResetGroupBy();//重置分組
$results = $sp->RunQuries();
批量查詢(或多查詢)使searchd能夠進(jìn)行可能的內(nèi)部?jī)?yōu)化,并且無(wú)論在任何情況下都會(huì)減少網(wǎng)絡(luò)連接和進(jìn)程創(chuàng)建方面的開(kāi)銷。相對(duì)于單獨(dú)的查詢,批量查詢不會(huì)引入任何額外的開(kāi)銷。因此當(dāng)您的Web頁(yè)運(yùn)行幾個(gè)不同的查詢時(shí),一定要考慮使用批量查詢。
例如,多次運(yùn)行同一個(gè)全文查詢,但使用不同的排序或分組設(shè)置,這會(huì)使searchd僅運(yùn)行一次開(kāi)銷昂貴的全文檢索和相關(guān)度計(jì)算,然后在此基礎(chǔ)上產(chǎn)生多個(gè)分組結(jié)果。
有時(shí)您不僅需要簡(jiǎn)單地顯示搜索結(jié)果,而且要顯示一些與類別相關(guān)的計(jì)數(shù)信息,例如按制造商分組后的產(chǎn)品數(shù)目,此時(shí)批量查詢會(huì)節(jié)約大量的開(kāi)銷。 若無(wú)批量查詢,您會(huì)必須將這些本質(zhì)上幾乎相同的查詢運(yùn)行多次并取回相同的匹配項(xiàng),最后產(chǎn)生不同的結(jié)果集。若使用批量查詢,您只須將這些查詢簡(jiǎn)單地組成一個(gè) 批量查詢,Sphinx會(huì)在內(nèi)部?jī)?yōu)化掉這些冗余的全文搜索。
AddQuery()在內(nèi)部存儲(chǔ)全部當(dāng)前設(shè)置狀態(tài)以及查詢,您也可在后續(xù)的AddQuery()調(diào)用中改變?cè)O(shè)置。早先加入的查詢不會(huì)被影響,實(shí)際上沒(méi)有任何辦法可以改變它們。
用上述代碼,第一個(gè)查詢會(huì)在“documents”索引上查詢“hello world”并將結(jié)果按相關(guān)度排序,第二個(gè)查詢會(huì)在“products”索引上查詢“ipod”并將結(jié)果按價(jià)格排序,第三個(gè)查詢?cè)凇癰ooks”索引上搜 索“harry potter”,結(jié)果仍按價(jià)格排序。注意,第二個(gè)SetSortMode()調(diào)用并不會(huì)影響第一個(gè)查詢(因?yàn)樗呀?jīng)被添加了),但后面的兩個(gè)查詢都會(huì)受影 響。
此外,在AddQuery()之前設(shè)置的任何過(guò)濾,都會(huì)被后續(xù)查詢繼續(xù)使用。因此,如果在第一個(gè)查詢前使用SetFilter(),則通過(guò) AddQuery()執(zhí)行的第二個(gè)查詢(以及隨后的批量查詢)都會(huì)應(yīng)用同樣的過(guò)濾,除非你先調(diào)用ResetFilters()來(lái)清除過(guò)濾規(guī)則。同時(shí),你還 可以隨時(shí)加入新的過(guò)濾規(guī)則
AddQuery()并不修改當(dāng)前狀態(tài)。也就是說(shuō),已有的全部排序、過(guò)濾和分組設(shè)置都不會(huì)因這個(gè)調(diào)用而發(fā)生改變,因此后續(xù)的查詢很容易地復(fù)用現(xiàn)有設(shè)置。
AddQuery()返回RunQueries()結(jié)果返回的數(shù)組中的一個(gè)下標(biāo)。它是一個(gè)從0開(kāi)始的遞增整數(shù),即,第一次調(diào)用返回0,第二次返回1,以此類推。這個(gè)方便的特性使你在需要這些下標(biāo)的時(shí)候不用手工記錄它們。
?>
相關(guān)文章
PHP框架Laravel學(xué)習(xí)心得體會(huì)
Laravel是一套簡(jiǎn)潔、優(yōu)雅的PHP Web開(kāi)發(fā)框架 (PHP Web Framework) 。在世界(不含中國(guó))PHP框架的占有率超過(guò)40%。下面通過(guò)本文給大家分享我的PHP框架Laravel學(xué)習(xí)心得體會(huì),歡迎大家給我留言2015-10-10
PHP實(shí)現(xiàn)chrome表單請(qǐng)求數(shù)據(jù)轉(zhuǎn)換為接口使用的json數(shù)據(jù)
這篇文章主要介紹了PHP實(shí)現(xiàn)chrome表單請(qǐng)求數(shù)據(jù)轉(zhuǎn)換為接口使用的json數(shù)據(jù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
Laravel 實(shí)現(xiàn)Controller向blade前臺(tái)模板賦值的四種方式小結(jié)
今天小編就為大家分享一篇Laravel 實(shí)現(xiàn)Controller向blade前臺(tái)模板賦值的四種方式小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
php用戶注冊(cè)頁(yè)面利用js進(jìn)行表單驗(yàn)證具體實(shí)例
這篇文章介紹了php用戶注冊(cè)頁(yè)面利用js進(jìn)行表單驗(yàn)證具體實(shí)例,有需要的朋友可以參考一下2013-10-10
從零開(kāi)始學(xué)YII2框架(一)通過(guò)Composer安裝Yii2框架
今天終于搞明白怎么安裝Yii2了。對(duì)于我這種小白來(lái)說(shuō)真是費(fèi)盡周折。下面來(lái)介紹下如何安裝Composer和如何使用Composer安裝Yii2。2014-08-08
新浪微博API開(kāi)發(fā)簡(jiǎn)介之用戶授權(quán)(PHP基礎(chǔ)篇)
己在開(kāi)發(fā)和學(xué)習(xí)的過(guò)程中,感覺(jué)雖然沒(méi)有太大難度,但還是有一些問(wèn)題是需要我們注意的,今天就我在開(kāi)發(fā)和學(xué)習(xí)的過(guò)程中,簡(jiǎn)單的對(duì)利用PHP進(jìn)行新浪微博API開(kāi)發(fā)的內(nèi)容進(jìn)行一個(gè)整理和說(shuō)明2011-09-09
AES加解密在php接口請(qǐng)求過(guò)程中的應(yīng)用示例
在我們的編程的過(guò)程中,經(jīng)常會(huì)遇到加密的情況,怎么才會(huì)合理運(yùn)用,本篇文章主要介紹了AES加解密在php接口請(qǐng)求過(guò)程中的應(yīng)用示例,有需要的可以了解一下。2016-10-10
php獲取POST數(shù)據(jù)的三種方法實(shí)例詳解
本文介紹php獲取POST數(shù)據(jù)的三種方法,第一種方法是$_POST,第二種方法是使用file_get_contents,第三種方法是使用全局變量$GLOBALS, 具體請(qǐng)看下面說(shuō)明2016-12-12

