강의

멘토링

로드맵

인프런 커뮤니티 질문&답변

Bruce Han님의 프로필 이미지
Bruce Han

작성한 질문수

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

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

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

해결된 질문

작성

·

12

0

9:05분 쯤에

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

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

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

답변 2

1

쿠케님의 프로필 이미지
쿠케
지식공유자

Bruce Han님, 안녕하세요!

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

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

1

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

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

인덱스 생성 시 ASC의 역할

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

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

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

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

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

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

Bruce Han님의 프로필 이미지
Bruce Han

작성한 질문수

질문하기