sql >> Databasteknik >  >> RDS >> Mysql

Välj data med max datumordning efter ett annat fält

DROP TABLE IF EXISTS my_table;

CREATE TABLE my_table 
(id INT NOT NULL AUTO_INCREMENT PRIMARY KEY
,reg_no CHAR(4) NOT NULL
,payment INT NOT NULL
,payday DATE NOT NULL
);

INSERT INTO my_table VALUES
(1,'S001',100,'2017/01/01'),
(2,'S001',500,'2017/02/01'),
(3,'S002',400,'2017/01/01'),
(4,'S002',1000,'2017/11/01');

SELECT x.* 
  FROM my_table x 
  JOIN 
     ( SELECT reg_no
            , MAX(payday) payday 
         FROM my_table 
        GROUP 
           BY reg_no
     ) y 
    ON y.reg_no = x.reg_no 
   AND y.payday = x.payday;
+----+--------+---------+------------+
| id | reg_no | payment | payday     |
+----+--------+---------+------------+
|  2 | S001   |     500 | 2017-02-01 |
|  4 | S002   |    1000 | 2017-11-01 |
+----+--------+---------+------------+
2 rows in set (0.01 sec)


  1. Hur programmerar man en MySQL-utlösare för att infoga rad i en annan tabell?

  2. Mysql, PDO - Liknande uttalande fungerar inte med bindParam

  3. Micronaut data native-image:Det finns ingen böna av typen [io.micronaut.data.operations.PrimaryRepositoryOperations]

  4. Flera men ömsesidigt uteslutande främmande nycklar - är det här vägen att gå?