|
<?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ù)為int時間戳
$cl->SetFilterRange("starttime",123,124);
//篩選價格
$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");
注意:會被SetGroupBy中的排序覆蓋
// 匹配查詢詞中的任意一個
$cl->SetMatchMode ( SPH_MATCH_ANY );
SPH_MATCH_ALL, 匹配所有查詢詞(默認(rèn)模式);
SPH_MATCH_ANY, 匹配查詢詞中的任意一個;
SPH_MATCH_PHRASE, 將整個查詢看作一個詞組,要求按順序完整匹配;
SPH_MATCH_BOOLEAN, 將查詢看作一個布爾表達(dá)式 (參見 第 5.2 節(jié) “布爾查詢語法”);
SPH_MATCH_EXTENDED, 將查詢看作一個CoreSeek/Sphinx內(nèi)部查詢語言的表達(dá)式 (參見 第 5.3 節(jié) “擴(kuò)展查詢語法”). 從版本Coreseek 3/Sphinx 0.9.9開始, 這個選項被選項SPH_MATCH_EXTENDED2代替,它提供了更多功能和更佳的性能。保留這個選項是為了與遺留的舊代碼兼容――這樣即使 Sphinx及其組件包括API升級的時候,舊的應(yīng)用程序代碼還能夠繼續(xù)工作。
SPH_MATCH_EXTENDED2, 使用第二版的“擴(kuò)展匹配模式”對查詢進(jìn)行匹配.
SPH_MATCH_FULLSCAN, 強制使用下文所述的“完整掃描”模式來對查詢進(jìn)行匹配。注意,在此模式下,所有的查詢詞都被忽略,盡管過濾器、過濾器范圍以及分組仍然起作用,但任何文本匹配都不會發(fā)生.
//從0開始查詢,查詢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)部優(yōu)化,并且無論在任何情況下都會減少網(wǎng)絡(luò)連接和進(jìn)程創(chuàng)建方面的開銷。相對于單獨的查詢,批量查詢不會引入任何額外的開銷。因此當(dāng)您的Web頁運行幾個不同的查詢時,一定要考慮使用批量查詢。
例如,多次運行同一個全文查詢,但使用不同的排序或分組設(shè)置,這會使searchd僅運行一次開銷昂貴的全文檢索和相關(guān)度計算,然后在此基礎(chǔ)上產(chǎn)生多個分組結(jié)果。
有時您不僅需要簡單地顯示搜索結(jié)果,而且要顯示一些與類別相關(guān)的計數(shù)信息,例如按制造商分組后的產(chǎn)品數(shù)目,此時批量查詢會節(jié)約大量的開銷。 若無批量查詢,您會必須將這些本質(zhì)上幾乎相同的查詢運行多次并取回相同的匹配項,最后產(chǎn)生不同的結(jié)果集。若使用批量查詢,您只須將這些查詢簡單地組成一個 批量查詢,Sphinx會在內(nèi)部優(yōu)化掉這些冗余的全文搜索。
AddQuery()在內(nèi)部存儲全部當(dāng)前設(shè)置狀態(tài)以及查詢,您也可在后續(xù)的AddQuery()調(diào)用中改變設(shè)置。早先加入的查詢不會被影響,實際上沒有任何辦法可以改變它們。
用上述代碼,第一個查詢會在“documents”索引上查詢“hello world”并將結(jié)果按相關(guān)度排序,第二個查詢會在“products”索引上查詢“ipod”并將結(jié)果按價格排序,第三個查詢在“books”索引上搜 索“harry potter”,結(jié)果仍按價格排序。注意,第二個SetSortMode()調(diào)用并不會影響第一個查詢(因為它已經(jīng)被添加了),但后面的兩個查詢都會受影 響。
此外,在AddQuery()之前設(shè)置的任何過濾,都會被后續(xù)查詢繼續(xù)使用。因此,如果在第一個查詢前使用SetFilter(),則通過 AddQuery()執(zhí)行的第二個查詢(以及隨后的批量查詢)都會應(yīng)用同樣的過濾,除非你先調(diào)用ResetFilters()來清除過濾規(guī)則。同時,你還 可以隨時加入新的過濾規(guī)則
AddQuery()并不修改當(dāng)前狀態(tài)。也就是說,已有的全部排序、過濾和分組設(shè)置都不會因這個調(diào)用而發(fā)生改變,因此后續(xù)的查詢很容易地復(fù)用現(xiàn)有設(shè)置。
AddQuery()返回RunQueries()結(jié)果返回的數(shù)組中的一個下標(biāo)。它是一個從0開始的遞增整數(shù),即,第一次調(diào)用返回0,第二次返回1,以此類推。這個方便的特性使你在需要這些下標(biāo)的時候不用手工記錄它們。
?>
php技術(shù):深入解析php之sphinx,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。