inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 데이터베이스 완전정복 [설계편]

[실습] 삭제 전략

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

해결된 질문

127

Joe Hidden

작성한 질문수 6

0

안녕하세요

 

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

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

답변 2

0

신동현

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

0

인프런 AI 인턴

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

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

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

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

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

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

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

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

어플리케이션 실행 후 에러에 관하여 질문 드립니다.

2

25

2

Monolith 아키텍쳐 질문

0

22

0

운영환경에 적용해볼 수 없을때...고민입니다 ㅠㅠ

0

37

1

추가 연습 문제 링크 주세요

0

24

0

용어 사전

0

40

2

개념적 모델링 - 실습

0

32

1

섹션8 강의자료가 안열려요

0

31

2

유튜브 시연 영상 추가 기능 강의 업로드 계획

0

19

2

DB 설계와 JPA 관련 질문입니다

0

27

1

관리자 페이지 질문

0

28

2

드랍 테이블로 지운 ordes에 대해서 질문

0

30

1

문제 풀이 1번 질문

0

34

1

twitterdb 연결이 안돼요

1

34

2

Kafka Cluster 구성도 질문

0

26

1

아주 작은 정오표 전달드립니다.

0

63

2

mysql워크벤치를 실행할때마다 오류가 뜹니다. 해결 방법좀 가르켜주세요.

0

58

1

온톨로지 구축

0

41

1

실제로 작은 기업에서 기획 롤

1

33

1

이제 인프런에서 강의 더 안산다. 후져....

0

53

3

order_product 까마귀발

0

52

2

소스코드 어디서 다운받아요?

0

72

7

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

0

143

3

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

0

131

2

인덱스 사용 패턴 질문

0

101

2