|
首先需要了解:
num_matches: 當(dāng)前返回的結(jié)果數(shù),<= limit設(shè)置值。
max_matches: 最多返回的結(jié)果數(shù),默認(rèn)為1000,用戶最多只能看到1000條搜索結(jié)果。這個(gè)是在csft_mysql.conf中設(shè)置的。
total_found: 結(jié)果總數(shù)。索引中所有滿足查詢條件的文檔總數(shù)。這個(gè)是在你查詢的返回結(jié)果中的數(shù)組中有的。當(dāng)然前提是你必須在query前設(shè)置:$this->sc->SetArrayResult(true);
total: 最多返回結(jié)果數(shù),取值取決于max_matches值和total_found值。如果total_found數(shù)超過max_matches,則total = max_matches,否則,total = total_found。這個(gè)也是在你查詢的返回結(jié)果中的數(shù)組中有的。當(dāng)然前提也是你必須在query前設(shè)置:$this->sc->SetArrayResult(true);
這樣,了解了這幾個(gè)屬性之后就可以做分頁了。
我們應(yīng)該使用返回值中的total來做分頁總數(shù)據(jù)。雖然這個(gè)不代表真實(shí)的返回值(當(dāng)返回值大于max_matches,也就是1000,如真實(shí)返回2500,但是你卻只能得到1000)。
代碼是:
復(fù)制代碼 代碼如下:
$this->sc->SetServer("127.0.0.1",9312);
$this->sc->SetArrayResult(true);
$this->sc->SetLimits($start,$page);
//如果需要搜索指定全文字段的內(nèi)容,可以使用擴(kuò)展匹配模式:
$this->sc->SetMatchMode(SPH_MATCH_ANY);
$res = $this->sc->Query($where,"main");
$count = $res['total'];
這個(gè)¥count就是我們要的分頁的總數(shù)據(jù)了。
其他的后續(xù)怎么分頁是以樣式和數(shù)據(jù)結(jié)構(gòu)做的,不能雷同,并且分頁也是基礎(chǔ)的東西,所以這里就不再多說分頁的詳細(xì)問題了。我這里單單討論這個(gè)總數(shù)據(jù)的取值情況。因?yàn)楹芏嗳硕既ount($res['matches'])的值,但是這個(gè)是分頁后的返回結(jié)果,你只能得到10,或者20或者其他的值。呵呵,那就搞笑了。
php技術(shù):關(guān)于使用coreseek并為其做分頁的介紹,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。