php取符合条件的一条,比较数据,只取符合要求的一条

本文介绍如何使用SQL或PHP代码实现一个报表,根据部门、分数和休息日规则,仅显示最高分或最低分的员工数据,即使休息日为负。通过示例和讨论解决了如何处理休息日条件的问题。

表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

就你的数据,这样就可以了

不太明白“如果休息(xiuxi)日小于0,取分数(fenshu)低的”的含义,数据中也没有提现出来

你的数据同一bumen可能出现两条 xiuxi =0 的数据吗?

发一个糟糕的方法,糟糕之处在于先查了整张表生成了一个不可控制体积的数组给PHP处理,以及循环后的不可知次数的循环....function getdata($sql){$result=mysql_query($sql);if($result)$count = mysql_num_rows($result);for($i=0;$i0){$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] => 1

[bumen] => 3

)

)

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)低的

这个可以去掉,因为不太可能存在这情况。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值