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);
}
}
}
?>