php递归,该如何处理
程序员文章站
2022-06-07 18:31:15
...
php递归
有一个数据表,结构如下:
id classid zengclassid createdate
需要递归查出classid=$id的zengclassid,还得判断zengclassid如果也有赠送的课程时,需要把这条记录也查出来,
例如:
1 470 445 2010-01-01 11:11:11
2 470 448 2010-01-01 11:11:11
3 448 457 2010-01-01 11:11:11
4 445 490 2010-01-01 11:11:11
如果查找id为470的结果,那么需要查出:445,448,457,490;
我的代码递归得有问题,请大虾们赐教一下
function getVideo_zs($classid,$arr){
global $dsql;
$sql = "SELECT zengclassid FROM course WHERE classid=".$classid;
$dsql->Execute('mme',$sql);
while($rs=$dsql->getArray('mme')){
$arr[] = $rs['zengclassid'];
if(!empty($rs['zengclassid'])){
$arr = getVideo_zs($rs['zengclassid'],$arr);
}
}
return $arr;
}
$zs_list = array();
$zs_zrr = getVideo_zs(470,$zs_list);
------解决方案--------------------
$arr[] = $rs['zengclassid'];//累积结果
if(!empty($rs['zengclassid'])){
$arr = getVideo_zs($rs['zengclassid'],$arr);//怎么递归一下就覆盖呢?
另外 $dsql->Execute('mme',$sql); 后,资源在 $dsql 内
请确认结果集不会被覆盖
有一个数据表,结构如下:
id classid zengclassid createdate
需要递归查出classid=$id的zengclassid,还得判断zengclassid如果也有赠送的课程时,需要把这条记录也查出来,
例如:
1 470 445 2010-01-01 11:11:11
2 470 448 2010-01-01 11:11:11
3 448 457 2010-01-01 11:11:11
4 445 490 2010-01-01 11:11:11
如果查找id为470的结果,那么需要查出:445,448,457,490;
我的代码递归得有问题,请大虾们赐教一下
function getVideo_zs($classid,$arr){
global $dsql;
$sql = "SELECT zengclassid FROM course WHERE classid=".$classid;
$dsql->Execute('mme',$sql);
while($rs=$dsql->getArray('mme')){
$arr[] = $rs['zengclassid'];
if(!empty($rs['zengclassid'])){
$arr = getVideo_zs($rs['zengclassid'],$arr);
}
}
return $arr;
}
$zs_list = array();
$zs_zrr = getVideo_zs(470,$zs_list);
------解决方案--------------------
$arr[] = $rs['zengclassid'];//累积结果
if(!empty($rs['zengclassid'])){
$arr = getVideo_zs($rs['zengclassid'],$arr);//怎么递归一下就覆盖呢?
另外 $dsql->Execute('mme',$sql); 后,资源在 $dsql 内
请确认结果集不会被覆盖
相关文章
相关视频
专题推荐
-
独孤九贱-php全栈开发教程
全栈 170W+
主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门
-
玉女心经-web前端开发教程
入门 80W+
主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门
-
天龙八部-实战开发教程
实战 120W+
主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论