Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Skomplikowane zapytanie MySQL

Możesz zrobić coś takiego:

SELECT 
    t1.post_id, 
    t1.meta_value AS name, 
    t2.meta_value AS season, 
    t3.meta_value AS episode
FROM
    (
    SELECT *
    FROM the_table
    WHERE meta_key = 'name'
    ) t1
INNER JOIN
    (
    SELECT *
    FROM the_table
    WHERE meta_key = 'season'
    ) t2 ON t1.post_id = t2.post_id
INNER JOIN
    (
    SELECT *
    FROM the_table
    WHERE meta_key = 'episode'
    ) t3 ON t1.post_id = t3.post_id

To da ci wynik:

| post_id | name       | season | episode |
-------------------------------------------
|    1    | Smallville | 1      | 1       |
|    2    | Smallville | 1      | 2       |

W tej formie jest znacznie łatwiej wykonywać dowolne operacje.

Musisz dodać:

WHERE name = 'Smallville'
ORDER BY season, episode


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Wyzwalacz MySQL - usuń po aktualizacji

  2. Dynamiczny MySQL ze zmiennymi lokalnymi

  3. Jak budować następne i poprzednie linki za pomocą php?

  4. Jak zaimportować plik XML do tabeli bazy danych MySQL za pomocą XML_LOAD(); funkcjonować

  5. Czy mogę przenieść tabelę MySQL na drugi dysk?