网站首页 | 站长论坛 | 免费空间申请 | 站长下载 | 站长博客 | 商业主机 | 免费空间推荐站点 | 免费空间排行榜 | 我们知道
发新话题
打印

[02-01] 无限分类&树型论坛的实现

[02-01] 无限分类&树型论坛的实现

无限分类&树型论坛的实现

数据表参考
CREATE TABLE `mf_sort` (
`sortid` SMALLINT( 3 ) UNSIGNED NOT NULL AUTO_INCREMENT ,
`main` TINYINT( 2 ) UNSIGNED NOT NULL ,
`parentid` SMALLINT( 3 ) UNSIGNED NOT NULL ,
`layer` SMALLINT( 3 ) UNSIGNED NOT NULL ,
`orders` TINYINT( 2 ) UNSIGNED NOT NULL ,
`sort` VARCHAR( 100 ) NOT NULL ,
PRIMARY KEY ( `sortid` ) ,
INDEX ( `main` , `parentid` , `layer` , `orders` )
);

#sortid 类别编号
#main  根分类
#parentid 父ID
#layer 分类等级
#orders 排列顺序
主要函数,用于添加分类时用,根分类除外:
function get_main_layer_orders($parentid)
{
    global $x_db;
    $sql  = "select `main`, `layer`, `orders` ";
    $sql .= "from `mf_sort` ";
    $sql .= "where `postid`='$parentid'";
    $x_db->exec($sql);
    $data   = $x_db->get_data();
    $layer  = $data[0]['layer']+1;
    $main   = $data[0]['main'];
    $orders = $data[0]['orders'];

    $sql  = "select `sortid` from `mf_sort` ";
    $sql .= "where `parentid`='$parentid'";
    $x_db->exec($sql);
    $n = $x_db->n;
    if ($n>0)
    {
        $lastid = $parentid;
        get_lastid($lastid);
        $sql    = "select `orders` from `mf_sort` ";
        $sql   .= "where `sortid`='$lastid'";
        $x_db->exec($sql);
        $data   = $x_db->get_data();
        $orders = $data[0][0];
        $sql    = "update `mf_sort` ";
        $sql   .= "set `orders`=`orders`+1 ";
        $sql   .= "where `orders`>$orders and `main`='$main'";
        $x_db->exec($sql);
        $orders = $orders + 1;
        return array($main, $layer, $orders);
    }
    else
    {
        $sql    = "update `mf_sort` ";
        $sql   .= "set `orders`=`orders`+1 ";
        $sql   .= "where `orders`>$orders and `main`='$main'";
        $x_db->exec($sql);
        return array($main, $layer, $orders+1);
    }
}

//取得最后一个有效sortid
function get_lastid(&$parentid)
{
    global $x_db;
    $pre  = $parentid;
    $sql  = "select max(`sortid`) as `id` ";
    $sql .= "from `mf_sort` ";
    $sql .= "where `parentid` = '$parentid'";
    $x_db->exec($sql);
    $data = $x_db->get_data();
    $id   = $data[0]['id'];
    if (empty($id))
    {
        $parentid = $pre;
    }
    else
    {
        $parentid = $id;
        get_lastid($parentid);
    }
}

TOP

呵呵``没有什么大用``

TOP

看了还是回下

TOP

看了还是回下

TOP

洋妞没兴趣

TOP

发新话题