1

すみません、簡単なゲストです。私はSqlが初めてです。だから、私はいくつかのSQLクエリを持っています。このSQLを1つのクエリに書きたいと思います!

$sql1=select 'max(id) as max1 FROM table where status_id=1 LIMIT 1';
$sql2=select 'max(id) as max2 FROM table where status_id=2 LIMIT 1';
$sql3=select 'max(id) as max3 FROM table where status_id=3 LIMIT 1';
$sql4=select 'max(id) as max4 FROM table where status_id=4 LIMIT 1';

$query1=mysql_query($sql1);
$fetch1=mysql_fetch_array($query1);
$query2=mysql_query($sql2);
$fetch2=mysql_fetch_array($query2);
$query3=mysql_query($sql3);
$fetch3=mysql_fetch_array($query3);
$query4=mysql_query($sql4);
$fetch4=mysql_fetch_array($query4);

echo 'Max ID numbers are:'.$fetch1['max1'].'; '.$fetch2['max2'].'; '.$fetch3['max3'].'; '.$fetch4['max4'].'';

これらの 4 つの SQL を 1 つのクエリで記述し、適切な ID を取得するにはどうすればよいですか? MYSQL UNION を試しましたが、結果はありませんでした。

4

2 に答える 2

1

使用group by:

select status_id, max(id) as maxValue FROM `table` 
where status_id in (1,2,3,4) group by status_id
于 2013-09-11T07:51:06.000 に答える