久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

帝國CMS跨表查詢相關鏈接實現方法

這篇文章主要為大家介紹了帝國CMS跨表查詢相關鏈接實現方法,通過一個自定義函數實現了跨表查詢相關鏈接的方法,是帝國CMS二次開發中非常實用的技巧,需要的朋友可以參考下

本文實例講述了帝國CMS跨表查詢相關鏈接實現方法。分享給大家供大家參考。具體分析如下:

官方的相關鏈接不靈活,樣式不能任意的修改且無法跨表,很多人想跨表做相關鏈接,比如news和info都有幾篇文章,關鍵詞都有'北京',那么如何調用這些有有同一關鍵詞的文章呢?為此寫了一個自定義函數.

小范圍的調用于本分類,稍大一點范圍可以調用同一表的文章,再大一點可以調用指定的表的文章,可以選要調用文章的數量,其實還可以升級,比如指定調用某個表的文章數量,那個表的順序等,函數沒有樣式,稍微懂一點代碼的可以自行修改,其實不是特別難,如果有哪位升級了這個函數,可以共享給大家.

復制代碼
代碼如下:
<?php
function user_OtherLink($tbname,$num,$ck){
global $navinfor,$empire,$dbtbpre,$class_r ;
$ck=(int)$ck ;
if($ck==1||$ck==2){
$tbname=$class_r[$navinfor['classid']]['tbname'] ;
}
$num= $num=='' ? 5 : $num ; //缺省獲取數量為5
$tag_all=explode(',',$navinfor['infotags']);
$tbname_num=explode(',',$tbname) ;
$eq_num=ceil($num/count($tag_all));
for($i=0;$i<count($tag_all);$i++){
$r_1_1 =$empire->fetch1("select tagid,tagname,num,isgood,cid from {$dbtbpre}enewstags where tagname='".$tag_all[$i]."' order by tagid limit 1") ;
$tag_id[$i]=$r_1_1['tagid'] ; //tag的ID
$tag_num[$i]=$r_1_1['num'] ; //tag下的文章數量
if($tag_num[$i]>=$eq_num){//如果TAG下的文章數量比平均的數量大或者等于,那么TAG的文章數量取平均值
$tag_num[$i] = $eq_num ;//重新賦值
}else{//如果TAG下的文章小于平均值,那么TAG取原有的文章數量。同時重新賦值平均值。
$eg_tag= $eq_num-$tag_num[$i] ;
$eq_num += $eg_tag ;
}
//比如說有3個TAG,每個TAG下有4篇文章,現在指定要顯示10篇文章,那么每個TAG要拿出4篇,共有12篇文章
//3個TAG,每個TAG下有3篇文章,現在指定要顯示10篇文章,那么每個TAG要拿出3篇文章,共有9篇文章
//3個TAG,A有2篇文章,B有5篇文章,C有3篇文章,現在要顯示10篇文章,那么A拿出2篇文章,B拿出5篇文章,C拿出3篇文章,共有10篇文章
//如果 A、B、C中除了當前文章,還有相同的文章,那么會扣除重復的那篇文章,只取一次。所以指定的數量會有偏差
for($i_n=0;$i_n<count($tbname_num);$i_n++){

$sql=$empire->query("select tid,classid,id,mid from {$dbtbpre}enewstagsdata where tagid='".$tag_id[$i]."' order by classid ");
$ri=1 ;
while($r=$empire->fetch($sql))
{
$tbname_all[$r['tid']]=$class_r[$r['classid']]['tbname'] ;
if($tbname_all[$r['tid']]==$tbname_num[$i_n] && $ri <= $tag_num[$i] && $navinfor['classid']!=$r['classid'] && $navinfor['id']!=$r['id']){
if($ck==1&&$navinfor['classid']==$r['classid']){

$tbname_all_r[$r['tid']]=$class_r[$r['classid']]['tbname'] ;
$classid_id[$r['tid']]=$r['classid'] . '_' . $r['id'] ;
$classid_all[$r['tid']]=$r['classid'] ;
$id_all[$r['tid']][$r['classid']]=$r['id'] ;

}elseif($ck==2&&$class_r[$navinfor['classid']]['tbname']==$class_r[$r['classid']]['tbname']){

$tbname_all_r[$r['tid']]=$class_r[$r['classid']]['tbname'] ;
$classid_id[$r['tid']]=$r['classid'] . '_' . $r['id'] ;
$classid_all[$r['tid']]=$r['classid'] ;
$id_all[$r['tid']][$r['classid']]=$r['id'] ;

}elseif($ck==3){

$tbname_all_r[$r['tid']]=$class_r[$r['classid']]['tbname'] ;
$classid_id[$r['tid']]=$r['classid'] . '_' . $r['id'] ;
$classid_all[$r['tid']]=$r['classid'] ;
$id_all[$r['tid']][$r['classid']]=$r['id'] ;

}
$ri++;
}
}
}
}
$classid_id_x=array_unique($classid_id);//去除重復的值
//去除重復的值,不同的TAG會有相同的文章。所以去除重復的值。比如A篇文章里面都有"北京","奧運",兩個關鍵詞,B篇文章里面也有"北京","奧運"在不去除重復的情況下,A篇的相關鏈接會出現兩次B文章。所以必須去除其中一個。
arsort($classid_id_x); //按鍵名排列,倒序
$tid_tid=array_keys($classid_id_x) ;//取出鍵名重新排列,鍵名即為TAG的ID:tid
shuffle($tid_tid);//順序打亂,重新排
$tid_tid_num=count($tid_tid) ;
if($num<$tid_tid_num) $tid_tid_num=$num+1 ;//由于去除了本文章,所以再加一條彌補
for($i_tid=0;$i_tid<$tid_tid_num;$i_tid++){
$tid=$tid_tid[$i_tid];
$classid=$classid_all[$tid];
$id=$id_all[$tid][$classid];
if($id==$navinfor['id']) continue ; //如果是本文章,相關鏈接里面就不用再放了。
$tbname=$tbname_all_r[$tid];
$r_1_2 =$empire->fetch1("select title,smalltext,titleurl,dp_jt,dp_dwz from {$dbtbpre}ecms_$tbname where id='".$id."' order by newstime limit 1") ;

////////顯示樣式在這修改
echo $r_1_2['title'].' ' ;
////////
}
}
?>
/**
<?php
OtherLink('news,info',7,3) ;
?>
**/

希望本文所述對大家的帝國CMS建站有所幫助。

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了ThinkPHP實現轉換數據庫查詢結果數據到對應類型的方法,涉及thinkPHP模型類操作及針對源碼文件的相關修改方法,需要的朋友可以參考下
下面小編就為大家帶來一篇利用PHP訪問數據庫_實現分頁功能與多條件查詢功能的示例。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
這篇文章主要介紹了thinkPHP多表查詢及分頁功能實現方法,結合具體實例形式分析了thinkPHP多表查詢以及查詢結果的分頁顯示相關實現技巧,需要的朋友可以參考下
這篇文章主要介紹了Yii框架參數化查詢中IN查詢只能查詢一個的解決方法,結合實例形式分析了Yii框架中IN查詢只能查一個的原因及FIND_IN_SET函數相關功能與使用技巧,需要的朋友可以參考下
這篇文章主要介紹了php實現查詢功能,數據進行訪問,具有一定的參考價值,感興趣的小伙伴們可以參考一下
這篇文章主要介紹了php+mysql+ajax實現單表多字段多關鍵詞查詢的方法,涉及php基于ajax的數據庫查詢、表格操作等相關技巧,需要的朋友可以參考下
主站蜘蛛池模板: 99精品国产一区二区三区 | 伊伊综合网 | 妞干网av | 国产精品一级 | 午夜欧美一区二区三区在线播放 | 国产精品国产精品国产专区不片 | 欧美精品一区二区蜜桃 | 99国产精品一区二区三区 | 成人激情免费视频 | 午夜免费看视频 | 亚洲精品一区在线观看 | www.亚洲.com | 91免费视频观看 | 岛国av免费看 | 欧美日韩在线观看视频网站 | 久久久毛片 | 欧美淫 | 欧美激情欧美激情在线五月 | 亚洲精品一区在线观看 | www.亚洲免费 | 99热在线观看精品 | 精品91视频 | 欧美三级免费观看 | www.亚洲.com| 天天躁天天操 | 一区二区三区不卡视频 | 午夜在线精品偷拍 | 都市激情亚洲 | 亚洲一区二区久久久 | 精品国产乱码久久久久久影片 | 一区二区视屏 | 欧美精品三区 | 少妇一区二区三区 | 欧美日韩在线一区二区 | 在线观看精品 | 欧美成人综合 | 亚洲交性 | 欧美日韩国产精品一区二区 | 国产91av视频在线观看 | 日本不卡一区 | 色婷婷综合久久久久中文一区二区 |