inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

[실습] 삭제 전략

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

해결된 질문

125

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 작업이 매우 빈번하게 발생하는 테이블의 경우 인덱스를 적절히 관리하여 그 성능 비용을 고려해야 합니다.

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

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

문제 풀이 1번 질문

0

11

0

twitterdb 연결이 안돼요

1

24

2

Kafka Cluster 구성도 질문

0

16

1

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

0

38

2

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

0

40

1

온톨로지 구축

0

25

1

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

1

25

1

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

0

40

1

order_product 까마귀발

0

41

2

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

0

52

5

정보처리기사 실기 zip

0

42

2

답을언제쯤받아볼수있나요

0

47

2

공통 코드 , 계층 구조 질문

1

35

1

데이터베이스 노션

0

37

2

수업노선자료파일 다운

0

34

2

프로젝트가 없어요..

0

56

2

소스코드 빈 파일 문의드려요

0

41

2

[DB설계] 탈퇴 유저의 구독 정보 유지 및 이메일 마스킹 관련 질문입니다.

0

52

1

자연키 vs 대리키 실무질문

0

28

1

handleBindException 의 기대의도가 방향이 맞는지 궁금합니다.

0

40

2

페이징 처리에서 offset/limit에 대한 질문

1

53

1

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

0

135

3

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

0

124

2

인덱스 사용 패턴 질문

0

99

2