inflearn logo
강의

講義

知識共有

実戦!データベース完全攻略 [設計編]

[実習] 削除戦略

논리적 삭제 적용시 INDEX 생성 전략

解決済みの質問

106

Joe Hidden

投稿した質問数 6

0

안녕하세요

 

논리적 삭제를 위한 컬럼 적용시 해당 테이블에서 조회할때 조회 조건에 항상 deleted_at 컬럼이 포함될거 같은데요 그러면 INDEX생성에 반영해주는게 좋을까요?

mysql dbms/rdbms database modeling db 카카오공채-개발

回答 2

0

qu3vipon

맞습니다. 논리적 삭제시 deleted_at 컬럼이 조회에 사용되기 때문에 인덱스를 추가하는 것이 좋습니다.

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. Joe Hidden님.

논리적 삭제를 다루는 경우, deleted_at과 같은 컬럼을 통해 실제로 삭제된 것이 아닌 레코드를 관리하는 방식이 일반적입니다. 이 경우, 해당 컬럼이 자주 조회 조건에 포함된다면 적절한 인덱스를 생성하는 것이 성능에 도움이 될 수 있습니다.

논리적 삭제와 인덱스 생성 고려사항

  1. 자주 사용되는 조건: deleted_at IS NULL 형태로 자주 조회된다면, 인덱스를 통해 해당 조건에 대한 검색을 최적화할 수 있습니다. 이로 인해 검색 속도가 향상되고, 필요하지 않은 레코드에 대한 불필요한 읽기 작업을 줄일 수 있습니다.

  2. 복합 인덱스: deleted_at 컬럼 뿐만 아니라 자주 검색조건으로 사용되는 다른 컬럼과 복합 인덱스를 만들면 효율을 극대화할 수 있습니다.

  3. 테이블 업데이트 영향: 인덱스의 작성 및 유지관리 자체가 비용이 됩니다. 따라서, insert, update 작업이 매우 빈번하게 발생하는 테이블의 경우 인덱스를 적절히 관리하여 그 성능 비용을 고려해야 합니다.

이와 관련된 더 구체적인 정보를 얻거나 예제를 참고하고 싶으시다면, 다음의 유사한 질문도 확인하시면 좋겠습니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

패키지 구분에 대해 궁금한게 있습니다

0

11

1

Substack 1년 제공

1

22

3

특별 학습 자료 프로모션 1년 멤버십 무료 제공 문의드립니다

0

27

2

스프링부트 서버 에러나요

0

17

1

코드를 첨부해야하는 이유가 있나요?

0

21

2

간단한 오타 제보입니다.

0

19

1

큰 범위 조회 시 EXPLAIN의 rows 값이 정확하지 않은 이유가 궁금합니다.

0

35

2

실제 FK제약조건을 설정하지 않는이유

0

37

2

조회속도 개선에서 더 개선하는 방법이 궁금합니다.

0

28

2

Sequence 관련 질문

1

32

2

Image Only Query

1

29

2

라이브 운영중인 환경의 테이블에 인덱스 추가시 고려사항

0

36

2

JPA Repository 질문이 있습니다!

1

34

2

페이지네이션 처리를 쿼리에서 하는 방식 질문

1

36

1

비동기 스레드풀 분리 이유와 Virtual Thread 전환 시 고려사항

0

36

1

수강기간 연장

0

27

1

25년 3회 1번 문제

0

37

2

Build 관련 문제 (테스트 관련 문제)

0

43

2

25년 2회 8~11 3:14

0

31

2

다양한 관점의 코드 경험을 위해 개선하지 않은 코드

1

47

1

BCNF 질문

0

49

2

커버링 인덱스에 대해서 질문드립니다.

0

95

3

인덱스 설계 시 컬럼 선택 기준

0

98

2

인덱스 사용 패턴 질문

0

78

2