-
Notifications
You must be signed in to change notification settings - Fork 1
데이터베이스 인덱싱
sieun edited this page Dec 4, 2024
·
1 revision
참고 자료: 효과적인 DB index 설정하기
카디널리티가 높으면(↑) 인덱스 설정에 좋은 컬럼이다.
-
카디널리티가 높다 = 한 컬럼이 갖고 있는 값의 중복도가 낮음. (= 값들이 대부분 다른 값을 가짐)
-
카디널리티가 낮다 = 한 컬럼이 갖고 있는 값의 중복도가 높음. (= 값들이 거의 같은 값을 가짐 )
선택도가 낮으면(↓) 인덱스 설정에 좋은 컬럼이다.
-
선택도가 높다 = 한 컬럼이 갖고 있는 값 하나로 여러 row가 찾아진다.
-
선택도가 낮다 = 한 컬럼이 갖고 있는 값 하나로 적은 row가 찾아진다.
조회 활용도가 높으면(↑) 인덱스 설정에 좋은 컬럼이다.
- 해당 컬럼이 실제 작업에서 얼마나 활용되는 지에 대한 값.
(
WHERE
의 대상 컬럼으로 많이 활용되는지로 판단하면 된다.)
수정 빈도가 낮으면(↓) 인덱스 설정에 좋은 컬럼이다.
- 인덱스도 테이블이기 때문에, 인덱스로 지정된 컬럼의 값이 바뀌게 되면 인덱스 테이블도 새롭게 갱신되어야 하기 때문.
우리 서비스의 order 테이블에서 빈번하게 사용하는 쿼리는 크게 다음 두 가지로 나뉜다.
SELECT * FROM orders WHERE status = 'PENDING' AND stock_code = '005930' AND trade_type = 'SELL';
SELECT * FROM orders WHERE user_id = '1' AND status = 'PENDING';
EXPLAIN SELECT * FROM orders WHERE status = 'PENDING' AND stock_code = '005930' AND trade_type = 'SELL';
EXPLAIN SELECT * FROM orders WHERE user_id = '1' AND status = 'PENDING';
위와 같은 코드를 실행했을 때, 기존 인덱스가 없는 실행 결과는 다음과 같이 full scan을 진행 중이라는 사실을 알 수 있다.
status나 trade_type 같은 경우에는 카디널리티가 높기 때문에 인덱스가 필요하지 않다고 생각하고, user_id와 stock_code에만 각각 인덱스를 걸어주었다.
인덱스를 생성한 후, 같은 쿼리를 실행하면 아래와 같이 인덱스를 이용해 조회하는 것을 확인할 수 있다.
order 테이블 외에도 asset, bookmark 테이블에 인덱스를 설정해 주었다.
- [FE] 프론트엔드 기술스택
- [FE] 라이브러리 없이 차트 구현 이유
- [FE] Canvas API 사용방법
- [FE] 네비게이션 바 애니메이션 구현
- [FE] Socket.io 사용방법
- [FE] Tanstack Router에 대하여...
- [FE] Intl(Internationalization) API
- [FE] React Suspense 적용
- [FE] 한글 입력 방식의 유연성을 높인 검색 시스템 구현하기
- [BE] 백엔드 기술 스택
- [BE] SSE vs Socket.io
- [BE] Redis를 도입하게 된 계기
- [BE] ACG Rule을 활용한 Secure CI CD 파이프라인 구현
- [BE] Nginx 로드밸런싱을 통해 한국 투자 API 소켓 제한 극복
- [BE] 주가 지수 기능 개발 과정
- [BE] 매수 및 매도 기능 개발 과정
- [BE] 실시간 자산 조회 기능 개발 과정
- [BE] 단위 테스트
- [BE] redis를 이용한 한국투자 Open API 세션 관리
- [BE] 데이터베이스 인덱싱
- [FE] React에서의 DOM 요소 접근 (useRef vs getElementById)
- [FE] Outlet을 활용한 공통 레이아웃 관리
- [FE] react hooks가 특정 조건에서 실행되면 안되는 이유 & useQuery에 query function 매개변수가 undefined일 수도 있을 때 어떻게 해결할까
- [FE] cross‐domain 로컬 환경에서 cookie로 인증 처리하기 with vite proxy
- [FE] 크롬&사파리 Composition 차이
- [FE] useEffect 의존성 배열
- [BE] Naver Cloud Platform HTTPS 무응답 현상
- [BE] 한국투자 Open API에서 access token을 발급받지 못하는 문제
- [BE] 한국투자 Open API와 웹소켓 연결이 되지 않던 문제
- [BE] 한국투자 Open API 웹소켓 연결이 중단되는 문제
- [BE] 같은 주식 주문이 동시에 여러 번 체결되는 문제
- [BE] 한국투자 Open API Websocket 세션을 두 개에서 한 개로 변경하기
- [BE] Nginx 로드 밸런싱 중 Socket bad Request 발생하는 현상
- [BE] 매수/매도 체결 로직에 의해 redis pub/sub이 정상적으로 동작하지 않는 문제