热搜:NVER node 开发 php

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

2024-09-19 19:40:01
比较数据,只取符合要求的一条

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