PHP 数据库树的遍历方法_php技巧
程序员文章站
2022-06-16 13:34:12
...
代码如下:
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;$iecho " ";
}
echo ' '.$rss['lsh'].$rss['name']."
";
Visit($rss['lsh'],$stept+1);
}
}
}
?>
复制代码 代码如下:
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;$iecho " ";
}
echo ' '.$rss['lsh'].$rss['name']."
";
Visit($rss['lsh'],$stept+1);
}
}
}
?>
推荐阅读
-
php查询mysql数据库并将结果保存到数组的方法_PHP教程
-
PHP下通过file_get_contents的代理使用方法_php技巧
-
PHP计算百度地图两个GPS坐标之间距离的方法_php技巧
-
PHP连接Sql数据库的相关方法_PHP教程
-
php+mysqli实现将数据库中一张表信息打印到表格里的方法_PHP
-
研究php开源源码的方法与技巧_PHP教程
-
PHP递归调用数组值并用其执行指定函数的方法_php技巧
-
php连接oracle数据库及查询数据的方法,oracle数据库_PHP教程
-
在任意字符集下正常显示网页的方法二(续)_php技巧
-
PHP登录环节防止sql注入的方法浅析_php技巧