해결된 질문
작성
·
15
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
의 역할기본 설정으로 작용: CREATE INDEX
문에서 ASC
를 명시하지 않으면 기본적으로 오름차순으로 인덱스가 생성됩니다. 즉, 특별한 이유가 없다면 ASC
를 명시할 필요는 없습니다.
명시적인 가독성: 개발 시 명시적으로 ASC
를 표기하는 것은 코드 가독성을 높이고 다른 개발자에게 의도를 명확히 전달할 수 있습니다. 이는 특히 DESC
(내림차순)와 혼동을 피하기 위해 도움이 됩니다.
특정 정렬이 필요한 경우: 만약 인덱스를 내림차순으로 생성하려는 경우, 명시적으로 DESC
를 지정해야 하며, 이 경우 ASC
를 표기하는 관습이 오히려 코드 일관성을 유지하는 데 도움이 될 수 있습니다.
결론적으로, 인덱스 생성 시 ASC
를 명시하는 것은 가독성을 높이는 데 주로 사용되며, 기본 기능적인 차이는 없습니다. 따라서 코드 스타일에 맞추어 사용하시면 됩니다.
유사한 주제를 다룬 관련 질문의 답변이 아래 링크에서 확인 가능합니다:
- MySQL 인덱스 생성 시 ASC/DESC의 차이와 사용법 바로가기
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.