sql >> Database >  >> RDS >> Mysql

Hoe deze gecompliceerde EAV MYSQL-query optimaliseren?

Eigenlijk heeft Chibuzo gelijk. Begin met het te verwijderen :-)) Maar speel er eerst een beetje mee, het is een goede hersenoefening, zoals schaken of zoiets :-)

select 
    case_id,
    d_status.data_field_value as case_status,
    d_client1_name.forename_company as client1_forename_company
from db_cases 
        join db_data as d_status 
            on d_status.data_case_id = case_id 
               AND d_status.data_field_name = 'casestatus'
        join db_data as d_client1
            on d_client1.data_case_id = case_id 
               AND d_client1.data_field_name = 'client1'
        join db_names as d_client1_name
            on d_client1_name.name_id = d_client1.data_field_value

Ik zou verwachten dat deze directe joins zonder subquery's veel efficiënter zouden zijn, hoewel je het zult moeten testen - er zijn vaak verrassingen in optimalisaties.




  1. Een SQL-query starten met een klik op de knop?

  2. TRUNC(getal) Functie in Oracle

  3. MySQL SELECTEER LIKE of REGEXP om meerdere woorden in één record te matchen

  4. Testen op beveiligingsproblemen in webapplicaties:best practices?