PHP 資料庫樹的遍曆方法

來源:互聯網
上載者:User

代碼如下: 複製代碼 代碼如下:<?php
session_start();
define ('P_S', PATH_SEPARATOR);
define ('ROOT', "./");
set_include_path(ROOT .P_S .'Zend' .P_S .ROOT.get_include_path());
//載入ZEND 架構
require_once ROOT.'Zend/Loader.php';
require_once 'usercheck.php';//載入存取權限
Zend_Loader::loadFile('function.class.php', $dirs='class/', $once=false);//載入函數
Zend_Loader::loadClass('Zend_Db');//載入資料庫類
Zend_Loader::loadClass('Zend_Config_Ini');//載入配置類
$config = new Zend_Config_Ini('config.php', 'general');//建立設定物件
$db = Zend_Db::factory($config->db->adapter,$config->db->config->toArray());//建立資料庫物件
$select=$db->select();
$select->from('ResClass',array('lsh','name'));
$select->where('steps = 1');
$rs=$db->fetchAll($select);
foreach ($rs as $res){
echo ' '.$res['lsh'].$res['name']."<br>";
Visit($res['lsh'],1);
}
function Visit($nodeid,$stept){
global $db;
$recordset = "SELECT lsh,name FROM ResClass WHERE parent=".$nodeid; //搜尋nodeid的所有下層節點
$rs=$db->fetchAll($recordset);
foreach($rs as $rss){
if(!$rss)
return; //已經是葉子節點,直接返回
else{
for ($i=0;$i<4*$stept;$i++){
echo " ";
}
echo ' '.$rss['lsh'].$rss['name']."<br>";
Visit($rss['lsh'],$stept+1);
}
}
}
?>
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.