Heim >Backend-Entwicklung >PHP-Tutorial >比较数据,只取符合要求的一条
表staff
id fenshu xiuxi bumen
1 80 0 2
2 80 1 2
3 90 2 2
4 60 0 3
要求:1.同一部门(bumen)的只显示一条数据
2.取值顺序,如果休息(xiuxi)日大于0的,取分数(fenshu)高的
3.如果休息(xiuxi)日小于0,取分数(fenshu)低的
如果只能以上数据,结果会是这样
id fenshu xiuxi bumen
3 90 2 2
求SQL代码或者PHP代码都可以。
4 60 0 3
这一条为什么没用?
4 60 0 3
这一条为什么没用?
也应该显示,我忽略了,
create table staff
(
id int(10),
fenshu int(10),
xiuxi int(10),
bumen int(10),
)
insert into staff (id,fenshu,xiuxi,bumen) values(1,80,0,2)
insert into staff (id,fenshu,xiuxi,bumen) values(2,80,1,2)
insert into staff (id,fenshu,xiuxi,bumen) values(3,90,2,2)
insert into staff (id,fenshu,xiuxi,bumen) values(4,60,0,3)
/*
要得到这样的报表:
id fenshu xiuxi bumen
3 90 2 2
4 60 0 3
*/
直接取最大的不行,感觉还要判断休息(xiuxi)日大于0只用sql不能实现呢。
select staff.* from staff, (select max(fenshu) as fenshu, bumen from staff group by bumen) t where staff.bumen = t.bumen and staff.fenshu=t.fenshu
你的数据同一bumen可能出现两条 xiuxi =0 的数据吗?
发一个糟糕的方法,糟糕之处在于先查了整张表生成了一个不可控制体积的数组给PHP处理,以及循环后的不可知次数的循环....
function getdata($sql){ $result=mysql_query($sql); if($result)$count = mysql_num_rows($result); for($i=0;$i<$count;$i++) { mysql_data_seek($result,$i); $data[$i] = mysql_fetch_assoc($result); } return $data;}$data = getdata("select sum(xiuxi) as xx,bumen from t3 group by bumen"); //查出所有部门对应的xiuxiif($data){ $res = array(); foreach($data as $each){ if($each['xx']>0){ $col = getdata("select * from t3 where bumen = '{$each['bumen']}' order by fenshu desc"); //如果xiuxi大于0,则倒序排列 }else{ $col = getdata("select * from t3 where bumen = '{$each['bumen']}' order by fenshu asc"); //反之则正序(xiuxi不会小于0吧? } if($col) $res[]=$col[0]; }}print_r($res);
Array
(
[0] => Array
(
[id] => 3
[fenshu] => 90
[xiuxi] => 2
[bumen] => 2
)
[1] => Array
(
[id] => 4
[fenshu] => 60
[xiuxi] => 0
[bumen] => 3
)
)
写错了溢出
一处................ 最近老打错别字不好意思..
to xuzuning ,
如果休息(xiuxi)日小于0,取分数(fenshu)低的
这个可以去掉,因为不太可能存在这情况。