sql >> Database teknologi >  >> RDS >> Mysql

SQL Hent hele rækken baseret på minimumværdien af ​​den beregnede kolonne

Forespørgslen nedenfor fungerer, men det er bedre at overveje at erstatte kolonnestatus med status_code med koden, og har en separat tabel status(status_code,description) {denormalisere}

Og indeksering (term_id,statUs_code ).

ved dette kan vi bare selv være med. Opret i stedet en visning som denne.

SELECT * FROM
(SELECT *,(CASE sample.status
                         WHEN 'Arrived' THEN 1
                         WHEN 'Active' THEN 2
                         WHEN 'Pending Approval' THEN 3
                         WHEN 'Pending Confirmation' THEN 4
                         WHEN 'Pending Manual' THEN 5
                         WHEN 'Denied' THEN 6
                         WHEN 'Canceled' THEN 7
                END) AS status_code FROM SAMPLE
  WHERE sample.term_id = 29
) my_view1,
(SELECT BED_ID,MIN(CASE sample.status
                         WHEN 'Arrived' THEN 1
                         WHEN 'Active' THEN 2
                         WHEN 'Pending Approval' THEN 3
                         WHEN 'Pending Confirmation' THEN 4
                         WHEN 'Pending Manual' THEN 5
                         WHEN 'Denied' THEN 6
                         WHEN 'Canceled' THEN 7
                END) AS status_code FROM SAMPLE
 WHERE sample.term_id = 29
 GROUP BY BED_ID
) my_view2
WHERE my_view1.bed_id = my_view2.bed_id
 AND  my_view1.status_code = my_view2.status_code



  1. Cloud9 postgres

  2. C#/NHibernate - Få de første 10 poster sorteret efter grupperet sum

  3. AWS Summits 2018:Chicago Recap

  4. Konverter 'smalldatetime' til 'datetime' i SQL Server (T-SQL-eksempler)