mysql 에서 숫자 필드와 문자 필드의 "성능" 차이가 궁금합니다.

pogusm의 이미지

실제 데이터는 A1 ~ A9999999 입니다. (필드명 : id)
이를 vchar 형태로 저장하는 방법과
'A'를 떼어내고 int 형태로 저장하는 방법이 있을텐데
저장공간 차이는 배제하고, select, insert 등의 쿼리에 대해서 DB 성능에 큰 차이가 있나요?

그리고 정수형태면 정렬에 문제가 없지만
vchar 형태로 저장했을때,
SELECT * FROM test ORDER BY id; 라고 하면 그 결과가
A1...A1000...A2...A2000...A3...A3000 와 같이 나오게 되는데,

이를 정수처럼 정렬하기 위해
SELECT * FROM test ORDER BY substring_index(id,'A',-1)+0;
또는
SELECT * FROM test ORDER BY substring(id,2)+0;
의 방법을 사용하는데,
이러면 A1, A2, A3, ... A1000 ... A2000 ... A3000 와 같이 나오게 됩니다.

이때도 정수형태를 다룰때와 성능상에서 큰 차이가 있을까요?

1. mysql 에서는 숫자와 문자간 성능 차이가 심하므로, 숫자로 처리할 수 있는 데이터는 무조건 숫자로 사용하라
라든지..
2. 성능차이가 있지만, 저러한 종류의 데이터가 여러종류일때 관리가 복잡해질 수 있으므로, 가급적 원데이타 형태를 그대로 사용하라
라든지..
3. 숫자든 문자든 별 차이 없다
라든지...
조언이 필요합니다.

ㅠㅠ

academic의 이미지

비슷한 질문을 두번 올려주셨네요.

너무 당연한 얘기지만...

문자로 처리할 데이터는 문자형으로 저장하는게 제일 빠르고, 숫자로 처리할 데이터는 숫자형으로 저장하는게 제일 빠릅니다.

말씀해주신 예에서 정수처럼 정렬하는 경우가 많다면, 당연히 정수형으로 저장하는 것을 권합니다.

정수처럼 처리하는 일이 많지만 속도는 느려도 되거나 혹은 정수처럼 처리할 일이 별로 없으면 당연히 원 데이터형으로 하는게 낫겠죠.

----
academic은 제 고등학교 때 동아리 이름입니다.
academic, 아주 가끔은 저도 이랬으면 좋겠습니다.

pogusm의 이미지

대부분 "문자" 형태로만 이용될 데이터이며 (정수로써 더하거나 할 일은 없음)

단지 정렬에 있어서만 정수 형태로 이용할 것인데
(문자 그대로 정렬 : A1...A1000...A2...A2000...A3...A3000)
(정수 형태로 정렬 : A1, A2, A3, ... A1000 ... A2000 ... A3000)

이 "정렬" 또한 그저 목록출력을 위한 것이기에

그냥 "원데이타" 형태 그대로로 사용하기로 하였습니다.

답변 감사합니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.