[튜닝일지] 4. 숫자 ID vs 텍스트 ID [백엔드 개발자의 쿼리 튜닝일지]

2024. 4. 27. 16:04·◈ Refactoring/쿼리 튜닝일지🔧
728x90
반응형

4. 숫자 ID vs 텍스트 ID

사이드 프로젝트를 준비하면서 고민한 ID 타입에 대한 공부와 고찰을 남겨보려 한다.

1) 숫자 ID [ ex) 3451832 ]

- 장점

  • 숫자는 일반적으로 텍스트보다 작은 공간을 차지하기 때문에 인덱스 생성 및 검색이 빠르다.
  • 데이터베이스에서 숫자 인덱스를 사용하면 메모리 사용량을 줄일 수 있다.
  • 자동 증가(Auto-increment)와 같은 기능을 이용하여 쉽게 새로운 ID를 생성할 수 있다.

- 단점

  • 가독성이 떨어질 수 있다. 숫자 ID는 사용자에게 의미 있는 정보를 전달하지 않는다.
  • 데이터베이스에서 무작위로 할당된 ID를 사용할 경우, 보안상의 문제가 발생할 수 있다.

2) 텍스트 ID [ ex) user123 ]

- 장점

  • 가독성이 좋다. 텍스트 ID는 해당 사용자를 직관적으로 나타낸다.
  • URL과 같이 외부에 노출되는 경우 유용하다.
  • 사람이 읽기 쉽고 이해하기 쉬운 ID는 사용자 경험을 향상시킬 수 있다.

- 단점

  • 텍스트를 사용하는 인덱스는 숫자 인덱스보다 더 많은 공간을 차지하고 검색 속도가 느릴 수 있다.
  • 문자열 비교에 의해 인덱스 생성이 오버헤드가 있을 수 있다.

3) 두 가지 유형을 혼합하여 사용한다면?

두 가지 유형의 ID를 혼합하여 사용하는 것은 각 유형의 ID가 가진 장점을 최대한 활용하면서도 단점을 보완할 수 있기에 특정 상황에 따라 유용할 수 있다. 그러나 주의사항도 있다.
  1. 가독성을 고려한 사용자 인터페이스 : 텍스트 ID를 사용하여 사용자가 이해하기 쉽고 가독성이 좋은 인터페이스를 제공할 수 있다. 게시글의 URL에는 텍스트 ID를 사용하여 사용자가 직관적으로 해당 게시글을 식별할 수 있다.
  2. 내부 데이터 처리 및 성능을 고려한 숫자 ID 사용 : 내부적으로는 숫자 ID를 사용하여 데이터베이스에서의 검색 및 인덱싱을 효율적으로 처리할 수 있다. 숫자 ID는 일반적으로 텍스트보다 작은 공간을 차지하고 인덱스 생성 및 검색이 빠르기 때문에 데이터베이스 성능을 향상시킬 수 있다.
  3. 일관성을 유지하는 관리 방식 : 두 가지 유형의 ID를 혼합하여 사용할 때는 일관성을 유지하는 것이 중요하다. 두 ID 간의 매핑 및 관리에 일관된 방식을 유지하여 데이터의 일관성을 보장해야 한다.
  4. 쿼리의 복잡성 관리 : 두 가지 유형의 ID를 혼합하여 사용할 경우, 쿼리의 복잡성이 증가할 수 있다. 두 ID 간의 변환 및 매핑을 고려하여 쿼리를 작성하고 관리해야 한다.
따라서 두 가지 유형의 ID를 혼합하여 사용하는 것은 가능하지만, 사용 사례와 요구 사항에 맞게 적절하게 고려해야 합니다. 데이터의 일관성과 가독성을 유지하면서도 성능을 향상시킬 수 있도록 조화롭게 구현해야 한다.

728x90
반응형
'◈ Refactoring/쿼리 튜닝일지🔧' 카테고리의 다른 글
  • [튜닝일지] 6. 너와 나의 연결고리, Mapping 테이블 [백엔드 개발자의 쿼리 튜닝일지]
  • [튜닝일지] 5. 쿼리문 조건에도 순서가 있다? [백엔드 개발자의 쿼리 튜닝일지]
  • [튜닝일지] 3. 믿었던 Function이 날 배신했다. [백엔드 개발자의 쿼리 튜닝일지]
  • [튜닝일지] 2. JOIN, 잘 좀 만나봅시다. (feat. or 조건) [백엔드 개발자의 쿼리 튜닝일지]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (987)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (30)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ Infra & DevOps (5)
        • LGTM Stack🔭 (5)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (80)
        • 백준(BOJ)👨🏻‍💻 (71)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
      • ◈ Study (129)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 알고리즘(Algorithm)🎡 (14)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (11)
        • 인공지능 AI🛸 (8)
      • ◈ 공부모임 (55)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (15)
        • 국가기술자격 서포터즈🌻 (12)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 정보보안기사⚜️ (0)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (124)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (55)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 반응형
    250x250
  • 태그

    html
    Oracle
    백준
    일상
    spring
    백준 티어
    코딩 테스트
    Project
    프로그래밍
    자바스크립트
    Error Note
    jsp
    javascript
    꿀팁
    Database
    CSS
    SQL
    Java
    코딩
    BOJ
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[튜닝일지] 4. 숫자 ID vs 텍스트 ID [백엔드 개발자의 쿼리 튜닝일지]
상단으로

티스토리툴바