여러 테이블에서 데이터를 가져 오기 위해 여러 조인을 사용하여 쿼리를 만들었습니다. 5000+ 레코드의 경우 매우 느리게 작동합니다. 나는 쿼리에 사용 된 각 테이블에 대해 제대로 점검하고 인덱스를 설정했습니다. 여러 옵션을 사용하여이 쿼리를 최적화하려고했지만 작동하지 않아 EXPLAIN 또는 EXPLAIN EXTENDED Help를 정확히 이해하지 못했습니다.다중 자기 조인과 인덱스로 My Moodle mysql 쿼리의 속도를 높이는 방법
=====
QUERY
EXPLAIN EXTENDED
SELECT @rownum := @rownum + 1 AS id,
u.id AS userid,
u.username AS employeeid,
u.firstname,
u.lastname,
u.email AS email,
u.city AS state,
c.fullname AS course,
c.id AS courseid,
c.fullname AS coursename,
fi2.data branchid,
fi3.data branchname,
fi6.data areaname,
fi7.data regname,
fi8.data designation,
fi9.data department,
fi10.data zone,
fi11.data branchcategory,
fi12.data branchdistrict,
fi13.data branchstate,
fi17.data gender,
fi21.data employeecategory,
fi22.data persontype,
fi23.data assignmentstatus,
fi30.data POSITION,
fi32.data dateofjoining,
fi33.data dateofbirth,
st.scoid,
st.scormid,
st.attempt,
st.value cmistarttime,
st5.value cmilessonstatus,
st5.timemodified cmitimemodified,
st3.value cmitotaltime,
st2.value cmiscore
FROM (
SELECT @rownum := 0
) r,
mdl_user u
JOIN mdl_role_assignments ra ON ra.userid = u.id
JOIN mdl_context ctx ON ctx.id = ra.contextid
JOIN mdl_course c ON c.id = ctx.instanceid
JOIN mdl_scorm s ON s.course = c.id
JOIN mdl_scorm_scoes_track st ON st.scormid = s.id AND st.userid = u.id
JOIN mdl_scorm_scoes_track AS st2 ON (u.id = st2.userid AND st2.scormid
= s.id AND st2.scoid = st.scoid AND st2.attempt = st.attempt)
JOIN mdl_scorm_scoes_track AS st3 ON (u.id = st3.userid AND st3.scormid
= s.id AND st3.scoid = st.scoid AND st3.attempt = st.attempt)
JOIN mdl_scorm_scoes_track AS st5 ON (u.id = st5.userid AND st5.scormid
= s.id AND st5.scoid = st.scoid AND st5.attempt = st.attempt)
JOIN mdl_user_info_data AS fi2 ON u.id = fi2.userid
JOIN mdl_user_info_data AS fi3 ON u.id = fi3.userid
JOIN mdl_user_info_data AS fi6 ON u.id = fi6.userid
JOIN mdl_user_info_data AS fi7 ON u.id = fi7.userid
JOIN mdl_user_info_data AS fi8 ON u.id = fi8.userid
JOIN mdl_user_info_data AS fi9 ON u.id = fi9.userid
JOIN mdl_user_info_data AS fi10 ON u.id = fi10.userid
JOIN mdl_user_info_data AS fi11 ON u.id = fi11.userid
JOIN mdl_user_info_data AS fi12 ON u.id = fi12.userid
JOIN mdl_user_info_data AS fi13 ON u.id = fi13.userid
JOIN mdl_user_info_data AS fi17 ON u.id = fi17.userid
JOIN mdl_user_info_data AS fi21 ON u.id = fi21.userid
JOIN mdl_user_info_data AS fi22 ON u.id = fi22.userid
JOIN mdl_user_info_data AS fi23 ON u.id = fi23.userid
JOIN mdl_user_info_data AS fi30 ON u.id = fi30.userid
JOIN mdl_user_info_data AS fi32 ON u.id = fi32.userid
JOIN mdl_user_info_data AS fi33 ON u.id = fi33.userid
WHERE c.id > 0 AND
u.id > 0 AND
u.deleted = 0 AND
u.suspended = 0 AND
u.confirmed = 1 AND
u.id <= 1000 AND
c.visible = 1 AND
st.element LIKE '%x.start.time%' AND
st2.element LIKE '%cmi.core.score.raw%' AND
st3.element LIKE '%cmi.core.total_time%' AND
st5.element LIKE '%cmi.core.lesson_status%' AND
fi2.fieldid = 2 AND
fi3.fieldid = 3 AND
fi6.fieldid = 6 AND
fi7.fieldid = 7 AND
fi8.fieldid = 8 AND
fi9.fieldid = 9 AND
fi10.fieldid = 10 AND
fi11.fieldid = 11 AND
fi12.fieldid = 12 AND
fi13.fieldid = 13 AND
fi17.fieldid = 17 AND
fi21.fieldid = 21 AND
fi22.fieldid = 22 AND
fi23.fieldid = 23 AND
fi30.fieldid = 30 AND
fi32.fieldid = 32 AND
fi33.fieldid = 33 AND
ra.roleid = 5 AND
ctx.contextlevel = 50
==========================
는 아마도이 질문은 https://codereview.stackexchange.com에 더 적합한 내 쿼리에 잘못된 경우 알려 주시기 바랍니다 그 주제를 벗어 나 여기 넓은 조금 보인다. – Jon
설명을 제공 한 것은 좋지만 기본 사항도 필요합니다. See : [매우 간단한 SQL 쿼리 인 것처럼 보이는 MCVE를 제공해야하는 이유는 무엇입니까?] (https://meta.stackoverflow.com/questions/333952/why-should-i-provide-an-mcve- for-what-like-to-me-to-be-a-very-simple-sql-query) - 거기에 텍스트를 수정 했습니까? 말할 수는 없지만 갖고 있다면 도움이되지 않습니다. – Strawberry
테이블 구조 또는 기타 세부 정보를보고 싶다면 다른 세부 정보를 공유하고 싶습니다. 실제로, 나는 전에 EXPLAIN을 사용하지 않았고 정확하게 그것이 나에게 어떤 점인지 이해하려고 노력했다. – user2791498