无限级分类,抓取某元素的所有下级id

mysql> select id,invite_qke_id from tf_qke;
+----+---------------+
| id | invite_qke_id |
+----+---------------+
|  2 |            19 |
| 11 |             2 |
| 13 |            11 |
| 14 |            13 |
| 16 |            14 |
| 17 |             2 |
| 18 |            17 |
| 19 |            18 |
+----+---------------+
8 rows in set (0.00 sec)

 

 
  
public function ttss(){
$id = 2;
$res = $this->son_ids($id,1);
dump($res);
}



public function son_ids($uid,$level,&$res_data = []){
$qkeModel = D('Qke');

if ($level == 1 && !$res_data){
$res_data[] = (string)$uid;
}

$sonlists = $qkeModel
->where(['invite_qke_id' => $uid])
->order('id desc')
->field('id,invite_qke_id')
->select();


if ($sonlists)
{
foreach ($sonlists as $k => $v)
{
echo $level;
// 这个拦截需在递归上面,放下面不行!!!!---防止最下级的下级是顶级,这样会陷入死循环!--会把服务器跑死!!!!!
if (in_array($v['id'],$res_data)){
continue;
}

$this->son_ids($v['id'],$level + 1,$res_data);

$res_data[] = $v['id'];
}

return $res_data;
}
}

 

<pre>

array(8) {
[0] => string(1) 2
[1] => string(2) 19
[2] => string(2) 18
[3] => string(2) 17
[4] => string(2) 16
[5] => string(2) 14
[6] => string(2) 13
[7] => string(2) 11
}
</pre>

 

 
 

 

转载于:https://www.cnblogs.com/pansidong/p/11387936.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值