您的位置:首页网页设计PHP实例 → 用PHP+MYSQL实现论坛里的分级+分页显示

用PHP+MYSQL实现论坛里的分级+分页显示

时间:2004/11/7 3:22:00来源:本站整理作者:蓝点我要评论(0)

用PHP+MYSQL实现论坛里的分级+分页显示



<?

/*存放贴子的表结构------------------------------------------------------



create table bbsrow(

    bbsrow_id int(6) not null auto_increment,  //贴子ID号

    bbsrow_auth varchar(20) not null,  //贴子作者

    bbsrow_parentid int(6),  //贴子的父亲贴子ID号,如为首发贴则为空

    bbsrow_title varchar(200) not null,  //贴子标题

    bbsrow_returncount int(3),  //贴子的回复贴数,如果没有回贴则为空

    primary key (bbsrow_id)

);

-----------------------------------------------------------------------------*/





//显示儿子贴的递归函数--------------------------------------------------

function showchildren($parent_id){

    global $connect_id;

    $query="select * from bbsrow where bbsrow_parentid='" . $parent_id . "'";     

    $result_top=mysql_query($query,$connect_id);

    echo "

n";


    while($myrow_child=mysql_fetch_row($result_top)){


        echo "

";

        echo $myrow_child[0];

        echo $myrow_child[1];

        echo $myrow_child[2];

        echo $myrow_child[3];

        echo $myrow_child[4] . "n";

        //如果回复贴数不为空,则表示有儿子贴,继续显示儿子贴

        if($myrow_child[4]!=''){

            showchildren($myrow_child[0]);

        }

    }

    echo "

";

}

//----------------------------------------------------------------------



//连接数据库并将所有首发贴放到$mainrow数组里----------------------------



$connect_id=mysql_connect("localhost","test","test") or die("无法连接数据库");

mysql_select_db("bbs") or die("无法选择数据库");

$query="select * from bbsrow where bbsrow_parentid=''";

$result=mysql_query($query,$connect_id);



$i=0;

while($myrow=mysql_fetch_row($result)) {

    $mainrow[$i][0]=$myrow[0];

    $mainrow[$i][1]=$myrow[1];

    $mainrow[$i][2]=$myrow[2];

    $mainrow[$i][3]=$myrow[3];

    $mainrow[$i][4]=$myrow[4];

    $i++;

}

mysql_free_result($result);

//----------------------------------------------------------------------



//开始构建分页显示------------------------------------------------------



if($currentpage!=""){

    $page=$currentpage;

}

else{

    $page=0;

}



$pagesize=10;//每页显示的首发贴数!

$start=$page*$pagesize;

$end=$start+$pagesize;

if($end>$i) $end=$i;

$totalpage=$i/$pagesize;



     

$info=" 共有" . $i . "条纪录,分" . ceil($totalpage) . "页,当前为第" . ($page+1) . "/" . ceil($totalpage) . "页
n";

echo $info;



if($page>0) $pagestr="上一页";

$pagestr=$pagestr . " [第 ";

     

for($i=0;$i<$totalpage;$i++){

    if($i!=$page){

        $pagestr=$pagestr . " " . ($i+1) . " ";

    }

    else{

        $pagestr=$pagestr . " " . ($i+1) . " ";

    }

}



$pagestr=$pagestr . "页]";

     

if($page<$totalpage-1) $pagestr=$pagestr . "下一页

n";

     

echo $pagestr;

//----------------------------------------------------------------------



//开始分级显示----------------------------------------------------------



echo "

n";


for($i=$start;$i<$end;$i++){


    echo "

n";

    echo $mainrow[$i][0];

    echo $mainrow[$i][1];

    echo $mainrow[$i][2];

    echo $mainrow[$i][3];

    echo $mainrow[$i][4] . "n";

    //如果回复贴数不为空,则表示有儿子贴,继续显示儿子贴

    if($mainrow[$i][4]!=''){

        showchildren($mainrow[$i][0]);

    }

}

echo "

n";

//----------------------------------------------------------------------?> 

相关阅读 Windows错误代码大全 Windows错误代码查询激活windows有什么用Mac QQ和Windows QQ聊天记录怎么合并 Mac QQ和Windows QQ聊天记录Windows 10自动更新怎么关闭 如何关闭Windows 10自动更新windows 10 rs4快速预览版17017下载错误问题Win10秋季创意者更新16291更新了什么 win10 16291更新内容windows10秋季创意者更新时间 windows10秋季创意者更新内容kb3150513补丁更新了什么 Windows 10补丁kb3150513是什么

文章评论
发表评论

热门文章 没有查询到任何记录。

最新文章 我的php文件怎么打开_php运算符怎么写 php 如何生成静态页面的函数PHP生成图片缩略图PHP session常见问题集锦及解决办法PHP实现同步远程Mysql

人气排行 DEDE在文章列表文章没有缩略图的不显示图片php+mysq修改用户密码我的php文件怎么打开_如何打开php文件的办法FCKeditor的配置和使用方法使用dedecms建站教程PHP+Ajax实现分页技术图片存储与浏览一例Linux+Apache+PHP+MySQLPHP生成图片缩略图