PHP 数据库树的遍历方法

前端之家收集整理的这篇文章主要介绍了PHP 数据库树的遍历方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

代码如下:
<div class="codetitle"><a style="CURSOR: pointer" data="48618" class="copybut" id="copybut48618" onclick="doCopy('code48618')"> 代码如下:

<div class="codebody" id="code48618">
<?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']."
";
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']."
";
Visit($RSS['lsh'],$stept+1);
}
}
}
?>

原文链接:https://www.f2er.com/php/29324.html

猜你在找的PHP相关文章