欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2024-01-05 18:58:16
...
表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)低的
这个可以去掉,因为不太可能存在这情况。

上一篇:

下一篇: