php部门的员工上下级,PHP按上下级层次关系输出内容_PHP教程

PHP按上下级层次关系输出内容

function getSubComments($parent = 0, $level = 0) {

$db = &JFactory::getDBO();

$sql = "..."; // 查询记录的SQL

$db->setQuery($sql);

$rows = $db->loadObjectList();

$list = array();

// 先从数据得到记录集,再对记录添加level, 父层level = 0,它的下级level = 1,如此类推

foreach ($rows as $row) {

$row->level = $level;

$list[] = $row;

$tmpArr = getSubComments($row->id, $level + 1); // 递归调用

if (count($tmpArr)) {

foreach ($tmpArr as $tmpRow) {

$list[] = $tmpRow;

}

}

}

return $list;

}

$list = array();

foreach ($tmpList as $row) {

$row->level = 0;

$list[] = $row;

$tmpList2 = getSubComments($row->id, 1);

foreach ($tmpList2 as $row2) {

$list[] = $row2;

}

}

// 按level分层次输出内容

if ($row->level) {

$pre = '';

for ($n = 0; $n < $row->level; $n++)

$pre .= '----';

echo $pre . '|- ';

}

echo strip_tags($row->content);

http://www.bkjia.com/PHPjc/364650.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/364650.htmlTechArticlePHP按上下级层次关系输出内容 function getSubComments($parent = 0, $level = 0) { $db = JFactory::getDBO(); $sql = ...; // 查询记录的SQL $db-setQuery($sql); $rows = $...

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设你的数据表结构如下: ``` id | name | parent_id ----|--------|---------- 1 | A | null 2 | B | 1 3 | C | 2 4 | D | 3 5 | E | 1 6 | F | 5 7 | G | 6 ``` 以下是一种递归查询指定ID下级所有人的方法: ```php function getSubordinates($id, $connection) { $subordinates = array(); $query = "SELECT * FROM your_table WHERE parent_id = $id"; $result = mysqli_query($connection, $query); while ($row = mysqli_fetch_assoc($result)) { $subordinates[] = $row; $subordinates = array_merge($subordinates, getSubordinates($row['id'], $connection)); } return $subordinates; } ``` 这个方法会返回一个包含所有下级的多维数组,例如: ```php $id = 2; $subordinates = getSubordinates($id, $connection); // 输出所有下级的名字 foreach ($subordinates as $subordinate) { echo $subordinate['name'] . "<br>"; } ``` 输出结果: ``` C D ``` 如果你要查询上上级所有下级下级的所有人,可以对上面的方法进行修改,将 `$id` 参数改成上上级的ID,例如: ```php $id = 1; // 上上级的ID $subordinates = array(); // 获取上上级所有下级的ID $query = "SELECT id FROM your_table WHERE parent_id = $id"; $result = mysqli_query($connection, $query); while ($row = mysqli_fetch_assoc($result)) { $subordinates = array_merge($subordinates, getSubordinates($row['id'], $connection)); } // 输出所有下级的名字 foreach ($subordinates as $subordinate) { echo $subordinate['name'] . "<br>"; } ``` 输出结果: ``` B C D E F G ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值