您好,登錄后才能下訂單哦!
本篇內容主要講解“如何使用coreseek并為其做分頁”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何使用coreseek并為其做分頁”吧!
coreseek 做分頁時找數據總量還真不好找。以為他會給一個方法(函數)什么的去獲取,結果卻不是。
首先需要了解:
num_matches: 當前返回的結果數,<= limit設置值。
max_matches: 最多返回的結果數,默認為1000,用戶最多只能看到1000條搜索結果。這個是在csft_mysql.conf中設置的。
total_found: 結果總數。索引中所有滿足查詢條件的文檔總數。這個是在你查詢的返回結果中的數組中有的。當然前提是你必須在query前設置:$this->sc->SetArrayResult(true);
total: 最多返回結果數,取值取決于max_matches值和total_found值。如果total_found數超過max_matches,則total = max_matches,否則,total = total_found。這個也是在你查詢的返回結果中的數組中有的。當然前提也是你必須在query前設置:$this->sc->SetArrayResult(true);
這樣,了解了這幾個屬性之后就可以做分頁了。
我們應該使用返回值中的total來做分頁總數據。雖然這個不代表真實的返回值(當返回值大于max_matches,也就是1000,如真實返回2500,但是你卻只能得到1000)。
代碼是:
復制代碼 代碼如下:
$this->sc->SetServer("127.0.0.1",9312);
$this->sc->SetArrayResult(true);
$this->sc->SetLimits($start,$page);
//如果需要搜索指定全文字段的內容,可以使用擴展匹配模式:
$this->sc->SetMatchMode(SPH_MATCH_ANY);
$res = $this->sc->Query($where,"main");
$count = $res['total'];
這個¥count就是我們要的分頁的總數據了。
其他的后續怎么分頁是以樣式和數據結構做的,不能雷同,并且分頁也是基礎的東西,所以這里就不再多說分頁的詳細問題了。我這里單單討論這個總數據的取值情況。因為很多人都取count($res['matches'])的值,但是這個是分頁后的返回結果,你只能得到10,或者20或者其他的值。呵呵,那就搞笑了。
到此,相信大家對“如何使用coreseek并為其做分頁”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。