在用PHPCMS做下載站時(shí)候,比較頭疼的就是目前的V9版竟然沒有下載次數(shù)統(tǒng)計(jì),而只能使用瀏覽次數(shù)來忽悠瀏覽者,呵呵,管他了,反正一般來訪者都不會(huì)太注意。
做下載總得有個(gè)下載排行吧,按照一般的邏輯,進(jìn)入某欄目,顯示的是某欄目的下載排行,而在首頁呢,應(yīng)該顯示的是全站所有軟件條目的下載排行。
雖說PHPCMS V9是新開發(fā)的,架構(gòu)比較好,但是錯(cuò)誤也不少,好多標(biāo)簽一同時(shí)使用后就出現(xiàn)異常了,頭都大了,也懶得整理放到官方論壇給他們修正,自己先避開,能不用就不用。
而我要說的就是,PHPCMS V9的標(biāo)簽竟然不支持重復(fù)調(diào)用多個(gè)欄目,例如我想顯示某兩個(gè)欄目的下載排行,V9就做不到了,而之前的2008版卻是可以支持的。令人費(fèi)解,只能認(rèn)為是新架構(gòu),還沒來得及完善了。
更難理解的是,瀏覽次數(shù)的表里面,與相關(guān)文章或下載內(nèi)容關(guān)聯(lián)的是一個(gè)叫“hitsid”的字段,同時(shí)也是該表的主鍵。存儲(chǔ)的字段內(nèi)容如“c-2-5”一類的,而不是普通的整型數(shù)字,不能簡單的與文章表或者下載表里面的條目的“id”號(hào)直接關(guān)聯(lián)就得到相關(guān)的瀏覽次數(shù),這個(gè)另類的“x-y-z”的方式令不少SQL語句的生手望而生畏,包括本人。
不過還好,這個(gè)“x-y-z”的格式是有規(guī)律可循的,于是乎,我查看了相關(guān)的文檔,想到了用字符串的形式,因?yàn)槲易龅氖窍螺d站,“x-y-”這段字符串是固定的,就是“c-2-”,第一個(gè)“c”是什么不知道,第二個(gè)“2”應(yīng)該是內(nèi)容模型,“2”是下載模型,“1”是文章模型,可以到模型管理里面查看id號(hào)。最后那個(gè)數(shù)字就是對(duì)應(yīng)的文章表或下載表里的條目id了,所以,也不是沒有方法的,我想到的就是在SQL語句里,將固定的“c-2-”和字段id合在一起,得到的就是諸如“c-2-5”一類的字符串,然后在用條件比對(duì)即可。
但是限于本人水平有限,這個(gè)字符串加了半天,沒有能夠成功。于是乎在網(wǎng)上漫無邊際的搜尋著,無意發(fā)現(xiàn)了CMS模板網(wǎng)某個(gè)網(wǎng)友分享的文章《Phpcms V9 替換頂級(jí)欄目頁面為列表頁及BUG修復(fù)》,從中找到了另一個(gè)方法,就是使用SQL語句的“substring”,我恍然大悟,這個(gè)方法也行得通的啊。先附上這位同學(xué)給出的方法:
頻道總排行調(diào)用方法
<div class="box">
<h5 class="title-2">頻道總排行</h5>
{pc:get sql="select a.id,a.title,a.url,a.catid,b.hitsid,b.views from v9_news a left join v9_hits b on a.id=substring(b.hitsid,5) where a.catid in ($arrchildid) order by b.views desc" num="10" cache="3600"}
<ul class="content digg">
{loop $data $r}
<li> <a href="{$r[url]}" title="{$r[title]}" target="_blank">{str_cut($r[title],36,'...')}</a></li>
{/loop}
</ul>
{/pc}
</div>
頻道月排行調(diào)用方法
<div class="box">
<h5 class="title-2">頻道本月排行</h5>
{pc:get sql="select a.id,a.title,a.url,a.catid,b.hitsid,b.views from v9_news a left join v9_hits b on a.id=substring(b.hitsid,5) where a.catid in ($arrchildid) order by b.monthviews desc" num="8" cache="3600"}
<ul class="content rank">
{loop $data $r}
<li><span>{number_format($r[views])}</span><a href="{$r[url]}"{title_style($r[style])} class="title" title="{$r[title]}">{str_cut($r[title],56,'...')}</a></li>
{/loop}
</ul>
{/pc}
</div>
這個(gè)就是兩個(gè)很好的例子。當(dāng)然我只用到了前一個(gè)例子中的SQL語句中的substring方法。Substring是截取字符串的作用,具體Substring的解釋詳見《SQL語句Substring用法》。
經(jīng)過上述例子學(xué)習(xí)后改進(jìn),雖然我的方法跟上面的多表聯(lián)查不一樣,但同樣得到了最后的調(diào)用全站所有文章排行的方法:
<div class="idxTopApps contents">
<ul class="indexIcns">
{pc:get sql="SELECT a.id,a.url,a.thumb,a.status,b.hitsid,b.views FROM v9_download a, v9_hits b WHERE a.status=99 and a.id=substring(b.hitsid,5) ORDER BY b.views DESC" num="6"}
{loop $data $r}
<li><a href="{$r['url']}"><img src="{$r['thumb']}" /></a></li>
{/loop}
{/pc}
</ul>
</div>
可以看到“substring(b.hitsid,5)”是截取hitsid字段,從左往右數(shù)第5個(gè)字符串,即“c-2-5”從左往右數(shù),1個(gè)“c”,1個(gè)“2”,2個(gè)“-”,第5個(gè)字符就是“5”,截取后只剩下了第2個(gè)“-”后的id,到達(dá)了最終提取id的目的。當(dāng)然,其中我還加入了另一個(gè)條件“status=99”,這個(gè)表示已經(jīng)審核通過的文章,這個(gè)可有可無。