table('oa_shijian')" で 2 つの隣接する値の差を取得する方法"/> table('oa_shijian')" で 2 つの隣接する値の差を取得する方法">
ホームページ >バックエンド開発 >PHPチュートリアル >ループ内で隣接する 2 つの値の差を取得する方法
循環の 2 つの相隣の数の差
function get_shijian_list($school_id,$parent_id)
{
$sql = "select shijian_id,name,type from ".$fdyu->table ('oa_shijian')." where parent_id=".$parent_id." and school_id=".$school_id." order by shijian_id asc";
$res = $db->query($sql);
$arr = array();
if($res)
{
while($row = $db->fetchRow($res))
{
//学员总人数
$xy_count = $db->getOne("SELECT COUNT(distinct xy.xy_id) FROM ".
$fdyu->table('oa_xueyuan')." as xy left join ".
$fdyu->table('oa_banji')." as bj on xy.cur_banji_id=bj.banji_id
(bj.shijian_1=".$row['shijian_id']." または bj.shijian_2=". $row['shijian_id']." または bj.shijian_3=".$row['shijian_id'].")
");
$sj_id = $row['shijian_id'];
$arr[$sj_id]['sj_id'] = $sj_id;
$arr[$sj_id]['xy_count_s'] = $xy_count;
}
}
return $arr;
}
循環中の $xy_count を計算し、2 つの相隣の差を計算します。例として、取得した $xy_count はそれぞれ 100、80、50 です。
100-80= を取得しました20
80-50-30
-----解决思路----------------------
简单点はfor
$arr = array(1,2,3,4);
for($i=0,$len=count($arr); に使用できます。 $i if($i>0){
echo $arr[$i]-$arr[$i-1];
}
}
- -----解决思路--------------------------
$last = '';<br />while($row = $db->fetchRow($res))<br />{<br /> //学员总人数<br /> $xy_count = $db->getOne("SELECT COUNT(distinct xy.xy_id) FROM ".<br /> if($last !== '') echo $last - $xy_count; //这里是打印,实际需要是什么你自己定<br /> $last = $xy_count; <br /><br /> //其他代码<br />}