Multiple left join optimizations

< H2 > tables: < / H2 >
  • employee
  • employee_orgn: federated primary key (employee_id,orgn_id), index 1, 2:orgn_id employees, index
  • orgn
< H2 > sql: < / H2 >
explain SELECT DISTINCT
    e.*
FROM
    employee e
        LEFT JOIN
    employee_orgn eo ON eo.employee_id = e.id
        LEFT JOIN
    orgn o ON o.id = eo.orgn_id
WHERE
    e.state != "deleted"
        AND e.state != "hidden"
        AND (o.state != "hidden" OR o.state IS NULL)
ORDER BY e.id DESC
< H2 > explain: < / H2 >

clipboard.png

Q:

  1. here join joint search, mysql nested loop query to the order of magnitude of 10 to the 8th?
  2. Why is there a temporary table, and why the sorting is file sorting
  3. Why is the second row an override index
  4. would like to explain the explain result and optimize the analysis

Thank you very much ~

Mar.31,2021

1. Notice that the header key_len, of the number 8 refers to the length of the index field.
2. Using tempory, Using filesort is affected by the order by statement. You can remove the order by and take a look at the execution plan.
3. It is reasonable for eo tables to use an overlay index because the index already contains all the data needed for the query.

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1b37abe-3447c.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1b37abe-3447c.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?