MySQL Workbench를 이용한 쿼리 개선
data:image/s3,"s3://crabby-images/e030e/e030ecaf84034c3106412f7e93b304e37a8052b2" alt=""
-> 확연한 개선 (Latency : 1120ms -> 894ms, Average : 579ms -> 380ms)
1번 쿼리 - todo_list 조회
data:image/s3,"s3://crabby-images/0e152/0e15244616a59a667f0c10d0127b8df88f1800bd" alt="image"
data:image/s3,"s3://crabby-images/fee22/fee2202b02f29912b7172409f6ce829b2f9c447f" alt=""
->
Query cost
index 제외 : 100.45
단일 index
- member만 : 12.35
- start_date만 : 109.61
복합 index(2개)
- member, start_date : 3.41
- start_date, member : 102.86
2번 쿼리 - 달성 개수 조회(2번 join이 들어감)
data:image/s3,"s3://crabby-images/11cd2/11cd20aad823cdcfcba81bcf9e384efa04edf375" alt="image"
data:image/s3,"s3://crabby-images/58b91/58b91bbf12fa8bb29975da9d58a6a03aacd7b406" alt=""
->
Query cost
index 제외 : 101.74
단일 index
- member만 : 34.23
- start_date만 : 113.64
- member, start_date : 61.08
복합 index(2개)
- member, start_date : 18.53
- start_date, member : 67.75
단일 index(todo에서)
- is_achieved : 19.44(전체 상황에서 동일)
3번 쿼리 - 좋아요 개수 조회(1번 join이 들어감)
data:image/s3,"s3://crabby-images/60bd3/60bd32c70f6b7553f8c28c0e9614d61bf01464e6" alt="image"
data:image/s3,"s3://crabby-images/e8e60/e8e609c6155ff7d31ade462b7e575c62d833fc4d" alt=""
->
Query cost
todo_list에서는 위에 비용이 적은 복합 index(2개, member, start_date를 적용)
1. index 제외 : 10.60
단일 index
- todo_list : 6.05