当前位置:Gxlcms > PHP教程 > 比较数据,只取符合要求的一条

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

时间:2021-07-01 10:21:17 帮助过:8人阅读

表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;$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] => 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)低的
这个可以去掉,因为不太可能存在这情况。

人气教程排行