Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

MySQL의 해당 중복 ID에서 가장 높은 금액 표시

<시간/>

해당 중복 ID에서 가장 많은 양을 표시하려면 GROUP BY 절과 함께 MAX()를 사용하십시오 -

mysql> create table DemoTable2003
(
   CustomerId int,
   Amount int
);
Query OK, 0 rows affected (0.65 sec)

삽입 명령을 사용하여 테이블에 일부 레코드 삽입 -

mysql> insert into DemoTable2003 values(101,560);
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable2003 values(102,1080);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable2003 values(101,570);
Query OK, 1 row affected (0.16 sec)
mysql> insert into DemoTable2003 values(102,870);
Query OK, 1 row affected (0.21 sec)
mysql> insert into DemoTable2003 values(101,460);
Query OK, 1 row affected (0.12 sec)

select 문을 사용하여 테이블의 모든 레코드 표시 -

mysql> select * from DemoTable2003;

이것은 다음과 같은 출력을 생성합니다 -

+------------+--------+
| CustomerId | Amount |
+------------+--------+
|        101 |    560 |
|        102 |   1080 |
|        101 |    570 |
|        102 |    870 |
|        101 |    460 |
+------------+--------+
5 rows in set (0.00 sec)

다음은 해당 중복 ID에서 가장 높은 금액을 표시하는 쿼리입니다. -

mysql> select CustomerId, max(Amount) from DemoTable2003
   group by CustomerId;

이것은 다음과 같은 출력을 생성합니다 -

+------------+-------------+
| CustomerId | max(Amount) |
+------------+-------------+
|        101 |         570 |
|        102 |        1080 |
+------------+-------------+
2 rows in set (0.00 sec)