[튜닝일지] 3. 믿었던 Function이 날 배신했다. [백엔드 개발자의 쿼리 튜닝일지]

2024. 4. 24. 12:20·◈ Refactoring/쿼리 튜닝일지🔧
728x90

3. 믿었던 Function이 날 배신했다.

지난 쿼리 튜닝으로 기존 대비 절반 이상으로 실행 속도를 절감시켰다.
그러나 여기서 튜닝을 멈추지 않았다. 아니 멈출 수 없었다.

쿼리 튜닝 나가신다, 길을 비켜라!

 

이번에 건드린 건 Function(≒Procedure, 프로시저)였다.
Function을 주석하고 실행하면 신기하게도 실행 속도가 빨라졌다.

 

왜 그런 것일까요?
GPT 선생님께 여쭤보았습니다.

 

GPT 선생님의 간단명료한 답변

더보기

MySQL에서 함수가 인덱스를 사용하는지 여부는 함수의 형태와 쿼리의 구성에 따라 다릅니다.


일반적으로, MySQL은 함수를 사용하여 쿼리를 실행할 때 인덱스를 사용하지 않습니다. 함수는 쿼리에서 조건절에 사용되는 경우 인덱스를 사용할 수 있는 기회를 제한합니다. 예를 들어, 다음과 같은 쿼리에서는 인덱스를 사용할 수 없습니다.

 

SELECT * FROM table WHERE my_function(column) = 'value';

 

위의 쿼리에서, my_function(column)이 함수를 호출하고 있기 때문에, 이는 인덱스를 사용하지 못하게 됩니다.


그러나 몇 가지 예외가 있습니다. MySQL에서 제공하는 함수 중 일부는 인덱스를 사용할 수 있습니다. 예를 들어, DATE_FORMAT() 함수는 적절한 경우에 인덱스를 사용할 수 있습니다.


또한, MySQL 5.7 이상에서는 "functional indexes"를 사용하여 함수 결과에 대한 인덱스를 만들 수 있습니다. 이렇게하면 함수 결과를 저장하고 인덱싱하여 쿼리 성능을 향상시킬 수 있습니다.


그러나 일반적으로 함수를 쿼리의 조건절에 직접 사용하는 것은 인덱스 사용을 제한하므로, 쿼리의 성능을 최적화하려면 함수를 사용하는 방법을 재고해야 할 수 있습니다.

 

MySQL에서 Function 안에 있는 쿼리는 인덱스를 타지 않았던 것..
해당 프로젝트는 5.7 이하 버전이였기에 Function을 모두 걷어내기로 결정!

F_로 시작하던 Function은 인덱스를 타지 않았다.
Function 안에 있던 쿼리로 모두 대체

 


 

Funciton을 모두 걷어내니 실행속도가 대폭 감소하였다.
2차 쿼리 튜닝 전후 속도 비교는 아래와 같다.


728x90
'◈ Refactoring/쿼리 튜닝일지🔧' 카테고리의 다른 글
  • [튜닝일지] 5. 쿼리문 조건에도 순서가 있다? [백엔드 개발자의 쿼리 튜닝일지]
  • [튜닝일지] 4. 숫자 ID vs 텍스트 ID [백엔드 개발자의 쿼리 튜닝일지]
  • [튜닝일지] 2. JOIN, 잘 좀 만나봅시다. (feat. or 조건) [백엔드 개발자의 쿼리 튜닝일지]
  • [튜닝일지] 1. Index, 너 잘 타고 있니? [백엔드 개발자의 쿼리 튜닝일지]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    코딩 테스트
    BOJ
    javascript
    CSS
    SQL
    프로그래밍
    jsp
    Java
    일상
    Database
    spring
    html
    Project
    Oracle
    코딩
    백준 티어
    꿀팁
    백준
    Error Note
    자바스크립트
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[튜닝일지] 3. 믿었던 Function이 날 배신했다. [백엔드 개발자의 쿼리 튜닝일지]
상단으로

티스토리툴바