inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링부트로 직접 만들면서 배우는 대규모 시스템 설계 - 게시판

댓글 무한 depth - 테이블&구현 설계

mysql 인덱스 생성 시 컬럼의 우선순위 질문

해결된 질문

77

Bruce Han

작성한 질문수 27

0

9:05분 쯤에

create unique index idx_article_id_path on comment_v2 (  article_id asc, path asc );

이렇게 인덱스 컬럼에 asc를 붙이신 이유가 있을까요? 생략할 수 있지 않나 해서요!

order by는 확실히 asc 생략해도 무방한데, 인덱스는 좀 헷갈려서 질문 드립니다.

mysql

답변 2

1

쿠케

Bruce Han님, 안녕하세요!

말씀하신대로 생략해도 무방하고, 별 이유는 없습니다!

개인적으로 생략해도 되는 디폴트 값이 있더라도 명확하게 표현하는걸 선호하기도 합니다.

1

인프런 AI 인턴

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

인덱스 생성 시 컬럼에 ASC (오름차순)을 명시하는 부분에 대해 설명드리겠습니다. SQL 표준에서는 인덱스를 생성할 때 기본적으로 ASC를 따르게 되어 있습니다. 따라서 인덱스를 만들 때 ASC를 생략해도 자동으로 오름차순으로 인덱스가 생성됩니다.

인덱스 생성 시 ASC의 역할

  1. 기본 설정으로 작용: CREATE INDEX 문에서 ASC를 명시하지 않으면 기본적으로 오름차순으로 인덱스가 생성됩니다. 즉, 특별한 이유가 없다면 ASC를 명시할 필요는 없습니다.

  2. 명시적인 가독성: 개발 시 명시적으로 ASC를 표기하는 것은 코드 가독성을 높이고 다른 개발자에게 의도를 명확히 전달할 수 있습니다. 이는 특히 DESC(내림차순)와 혼동을 피하기 위해 도움이 됩니다.

  3. 특정 정렬이 필요한 경우: 만약 인덱스를 내림차순으로 생성하려는 경우, 명시적으로 DESC를 지정해야 하며, 이 경우 ASC를 표기하는 관습이 오히려 코드 일관성을 유지하는 데 도움이 될 수 있습니다.

결론적으로, 인덱스 생성 시 ASC를 명시하는 것은 가독성을 높이는 데 주로 사용되며, 기본 기능적인 차이는 없습니다. 따라서 코드 스타일에 맞추어 사용하시면 됩니다.

유사한 주제를 다룬 관련 질문의 답변이 아래 링크에서 확인 가능합니다:
- MySQL 인덱스 생성 시 ASC/DESC의 차이와 사용법 바로가기

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

Kafka Cluster 구성도 질문

0

23

1

@Version 어노테이션이 붙은 필드는 낙관적 락이든 비관적 락이든 업데이트가 됩니다.

0

52

1

consumer에서 에러가 발생할 경우 데이터 유실 문의

0

66

2

게시글 테스트 데이터 삽입

0

62

2

정렬, 필터, 검색 등의 조건이 붙을 경우 최적화할 수 있는 방법이 무엇이 있을까요?

0

116

2

좋아요 기능 정합성 보장 방법

0

108

2

좋아요 동시성처리 최적의 선택?

1

151

2

프론트엔드 msa 환경 api 주소 통합? 과 서버끼리 통신 방식에대해

0

99

2

안녕하세요 무한스크롤 강의듣다가 질문이 있습니다.

0

65

1

조회수 조회 로직 질문

1

77

2

비로그인 유저도 어뷰징 방지 정책

1

78

2

CommentServiceTest의 테스트 로직 질문

0

58

2

무한 스크롤 방식에서 페이지 번호 방식 쿼리의 문제점 의문

1

77

2

path 쿼리 관련 질문드립니다!

0

66

2

antigravity 에디터를 쓰신다면 종료해주세요

1

127

0

프로젝트 구조

0

92

2

article_like_count api test

0

85

2

이벤트 페이로드 객체의 생성 방식이 팩토리 메서드 패턴이 아닌 빌더 패턴인 이유가 궁금합니다!.

0

107

2

[33. 좋아요 수 구현] 에서 테스트 하는 화면 동시성 문제

0

94

2

findByPath에서 articleId로도 검색을 해야 할 것 같아요.

0

104

3

jpa ddl-auto none을 하는 이유와 join 방법

0

102

2

팩터리 메소드와 response 객체 사용 이유가 궁금합니다!

0

95

2

커서 기반 페이지네이션 과 무한 스크롤링

0

120

2

게시글 생성 로직에서 오류 발생시 redis 게시글 수 되돌리기

0

103

2