举个栗子,假如f的下一个成员是g,f是g的父级,g的value值为190,
那么最后计算出的结果就是在d这一父级的时候,g和g的所有父级的value值总在d这一级的时候总值达到了203,突破了200,那么d这个成员就是我最后要的结果。
那么最后计算出的结果就是在d这一父级的时候,g和g的所有父级的value值总在d这一级的时候总值达到了203,突破了200,那么d这个成员就是我最后要的结果。
解决方案 »
- access的索引怎么用啊?
- wap中的文本框不能点击到输入文字
- 如何计算表中相邻的两条记录的某时间字段的值之差
- 已知带有级数的数组,求无序列表。
- 如何加上排除组合出来的重复号码
- PHP中heredoc的用法,请勿上网粘贴!
- PHP目前最高是什么版本,最稳定是哪个版本?
- 问题还没解决,再请教--Fatal error: Call to undefined function: socket_create()...
- ASP中有没有象PHPlib那样的模板,把HTML和ASP代码分开写
- 应该是小菜一碟吧
- smarty的自动过滤$smarty->auto_literal 会影响整体效能吗?
- 点击列头进行排序(表格中的数据为动态数据)
//类里面的递归函数
function test($id,$num=0,$max=200){
$sql="SELECT * FROM {{test}} WHERE id=$id";
$res=Yii::app()->db->createCommand($sql)->queryRow();
$num+=$res['value'];
if($num<$max){
$name=self::test($res['pid'],$num);
}else{
$name=$res['name'];
}
return $name;
}//调用
$tr=new classtest();
echo $tr->test(7);
//结果 d
order by pid desc
然后循环fetch即可, 给个奇葩的sql,(符合上面条件的情况下)
select * from (
select id, pid, `value`,
if(id=@p, concat(@p:=pid,'|',@a := @a+`value`), ''), if(@a>@s, id, '-') as Final, @a
from test, (select @a:=0, @p:=6, @s:=30) x -- 其中6改成你所选择的成员的id, 30 改成你的界(200)
where @a<@s
order by pid desc, id
) y
where Final!='-'
limit 1
;
当然实际上在php里计算比较方便。
如果不满足这个条件的话。好像只能反复查询了