찾다
시스템 튜토리얼리눅스MySQL 고성능 테이블을 설계하는 방법

MySQL 고성능 테이블을 설계하는 방법

Jan 07, 2024 pm 11:54 PM
linux리눅스 튜토리얼레드햇리눅스 시스템리눅스 명령리눅스 인증빨간 모자 리눅스리눅스 비디오

훌륭한 논리적 설계와 물리적 설계는 고성능의 초석입니다. 시스템이 실행할 쿼리문에 따라 스키마를 설계해야 하며, 이는 종종 다양한 요소를 고려해야 합니다.

MySQL 고성능 테이블을 설계하는 방법

1. 최적화된 데이터 유형을 선택하세요

MySQL은 다양한 데이터 유형을 지원합니다. 올바른 데이터 유형을 선택하는 것은 고성능을 달성하는 데 중요합니다.

일반적으로 작은 것이 더 좋습니다

데이터 유형이 작을수록 디스크, 메모리, CPU 캐시를 덜 차지하고 처리하는 데 필요한 CPU 주기가 더 적기 때문에 일반적으로 속도가 더 빠릅니다.

단순하게 유지하세요

단순 데이터 유형에 대한 작업에는 일반적으로 더 적은 CPU 주기가 필요합니다. 예를 들어, 문자 집합과 대조 규칙(조합)으로 인해 문자 비교가 정수 비교보다 더 복잡해지기 때문에 정수 연산은 문자 연산보다 저렴합니다.

NULL을 피하세요

쿼리에 NULL 열이 포함된 경우 NULL 열로 인해 인덱스, 인덱스 통계 및 값 비교가 더 복잡해지기 때문에 MySQL이 최적화하기가 더 어렵습니다. NULL이 될 수 있는 열은 더 많은 저장 공간을 사용하고 MySQL에서 특별한 처리가 필요합니다. NULL 가능 열이 인덱싱되면 각 인덱스 레코드에는 추가 바이트가 필요하며 이로 인해 MyISAM에서는 고정 크기 인덱스(예: 정수 열이 하나만 있는 인덱스)가 가변 크기 인덱스가 될 수도 있습니다.

물론 예외도 있습니다. 예를 들어 InnoDB는 NULL 값을 저장하기 위해 별도의 비트를 사용하므로 희소 데이터에 대한 공간 효율성이 좋습니다.

1. 정수형

숫자에는 정수와 실수의 두 가지 유형이 있습니다. 정수를 저장하는 경우 TINYINT, SMALLINT, MEDIUMINT, INT, BIGINT와 같은 정수 유형을 사용할 수 있습니다. 각각 8, 16, 24, 32, 64비트 저장 공간을 사용하세요.

정수 유형에는 선택적 **UNSIGNED** 속성이 있습니다. 이는 음수 값이 허용되지 않음을 의미하며 이는 양수의 상한을 대략 두 배로 늘립니다. 예를 들어 TINYINT.UNSIGNED는 0 - 255 범위를 저장할 수 있는 반면 TINYINT의 저장 범위는 -128 -127입니다.

Signed 타입과 unsigned 타입은 동일한 저장공간을 사용하고 동일한 성능을 가지므로 실제 상황에 따라 적절한 타입을 선택하시면 됩니다.

귀하의 선택에 따라 MySQL이 메모리와 디스크에 데이터를 저장하는 방법이 결정됩니다. 그러나 정수 계산에서는 32비트 환경에서도 일반적으로 64비트 BIGINT 정수를 사용합니다. (예외는 계산에 DECIMAL 또는 DOUBLE을 사용하는 일부 집계 함수입니다.)

MySQL은 INT(11)와 같은 정수 유형의 너비를 지정할 수 있습니다. 이는 대부분의 응용 프로그램에서는 의미가 없습니다. 이는 값의 합법적인 범위를 제한하지 않고 MySQL의 일부 대화형 도구(예: MySQL 명령줄 클라이언트)만 지정합니다. ) 문자 수를 표시하는데 사용됩니다. 저장 및 계산 목적에서는 INT(1)과 INT(20)이 동일합니다.

2.실수형

실수는 소수 부분이 있는 숫자입니다. 그러나 소수 부분만 저장하는 것이 아니라 DECIMAL을 사용하여 BIGINT보다 큰 정수를 저장할 수도 있습니다.

FLOAT 및 DOUBLE 유형은 표준 부동 소수점 연산을 사용한 대략적인 계산을 지원합니다.

DECIMAL 유형은 정확한 소수점을 저장하는 데 사용됩니다.

부동 소수점 유형과 DECIMAL 유형 모두 정밀도를 지정할 수 있습니다. DECIMAL 열의 경우 소수점 앞뒤에 허용되는 최대 자릿수를 지정할 수 있습니다. 이는 열의 공간 소비에 영향을 미칩니다.

부동 소수점 열에 필요한 정밀도를 지정하는 방법은 다양하며, 이로 인해 MySQL이 다른 데이터 유형을 선택하거나 저장할 때 값을 반올림하게 됩니다. 이러한 정밀도 정의는 비표준이므로 정밀도가 아닌 데이터 유형만 지정하는 것이 좋습니다.

부동 소수점 유형은 일반적으로 동일한 범위에 값을 저장할 때 DECIMAL보다 적은 공간을 사용합니다. FLOAT는 4바이트의 저장 공간을 사용합니다. DOUBLE은 8바이트를 차지하며 FLOAT보다 정밀도가 높고 범위가 넓습니다. 정수 유형과 마찬가지로 선택할 수 있는 것은 저장 유형뿐입니다. MySQL은 내부 부동 소수점 계산을 위한 유형으로 DOUBLE을 사용합니다.

추가 공간과 계산 오버헤드가 필요하므로 소수에 대한 정확한 계산을 수행할 때는 DECIMAL만 사용하도록 노력해야 합니다. 하지만 데이터가 비교적 큰 경우 DECIMAL 대신 BIGINT를 사용하는 것을 고려해 볼 수 있습니다. 저장할 통화 단위에 소수 자릿수에 따라 해당 배수를 곱하면 됩니다.

3. 문자열 유형

VARCHAR

  • 변수 문자열을 저장하는데 사용되며, 길이는 65535까지 지원됩니다
  • 문자열 길이를 기록하려면 1~2바이트의 추가 바이트가 필요합니다
  • 적합 대상: 문자열의 최대 길이가 평균 길이보다 훨씬 깁니다. 업데이트는 거의 없습니다.

CHAR

    고정 길이, 길이 범위는 1~255
  • 적합: 매우 짧은 문자열을 저장하거나 자주 변경되는 동일한 길이에 가까운 모든 값을 저장합니다.
관대함은 현명하지 못하다

VARCHAR(5)와 VARCHAR(200)을 사용하여 'hello'를 저장하는 공간 오버헤드는 동일합니다. 그렇다면 더 짧은 열을 사용하면 어떤 이점이 있습니까?

큰 장점이 있는 것으로 나타났습니다. MySQL은 일반적으로 내부 값을 보관하기 위해 고정 크기의 메모리 블록을 할당하기 때문에 열이 길수록 더 많은 메모리를 사용합니다. 이는 정렬이나 작업을 위해 메모리 내 임시 테이블을 사용할 때 특히 나쁩니다. 디스크 임시 테이블을 사용하여 정렬할 때도 마찬가지로 나쁩니다.

그래서 가장 좋은 전략은 꼭 필요한 공간만 할당하는 것입니다.

4.BLOB 및 TEXT 유형

BLOB 및 TEXT는 모두 대용량 데이터를 저장하도록 설계된 문자열 데이터 유형이며 각각 바이너리 및 문자 모드로 저장됩니다.

다른 유형과 달리 MySQL은 각 BLOB 및 TEXT 값을 독립적인 개체로 처리합니다. 스토리지 엔진은 일반적으로 저장할 때 특수 처리를 수행합니다. BLOB 및 TEXT 값이 너무 크면 InnoDB는 저장을 위해 전용 "외부" 저장 영역을 사용합니다. 이때 각 값은 행에 저장되기 위해 1~4바이트가 필요합니다. .

BLOB와 TEXT의 유일한 차이점은 BLOB 유형은 이진 데이터를 저장하고 대조나 문자 집합이 없는 반면, TEXT 유형은 문자 집합과 대조가 있다는 것입니다

5.날짜 및 시간 유형

대부분의 경우 유형에 대한 대안이 없으므로 무엇이 최선의 선택인지 의문의 여지가 없습니다. 유일한 문제는 날짜와 시간을 저장할 때 무엇을 해야 하느냐는 것입니다. MySQL은 DATE TIME과 TIMESTAMP라는 두 가지 유사한 날짜 유형을 제공합니다.

하지만 현재는 타임스탬프를 저장하는 방식을 선호하므로 여기서는 DATE TIME과 TIMESTAMP에 대해 자세히 설명하지 않겠습니다.

6.기타 유형

6.1 식별자 선택

가장 작은 데이터 유형은 가치 범위의 요구 사항을 충족하고 향후 성장 여지를 남겨둘 수 있다는 전제 하에 선택해야 합니다.

  • 정수형

정수는 속도가 빠르고 AUTO_INCREMENT를 사용할 수 있기 때문에 일반적으로 ID 열에 가장 적합합니다.

  • ENUM 및 SET 유형

EMUM 및 SET 유형은 고정된 상태나 유형만 포함하는 일부 정적 "정의 테이블"에는 적합할 수 있지만 일반적으로 ID 열에는 적합하지 않습니다. ENUM, SET 컬럼은 주문현황, 제품종류, 성별 등 고정정보를 저장하는데 적합하다.

  • 문자열 유형

가능한 경우 문자열 유형은 공간을 많이 소비하고 일반적으로 숫자 유형보다 느리기 때문에 ID 열로 사용하지 않는 것이 좋습니다.

MDS(), SHAl() 또는 UUID()에 의해 생성된 문자열과 같이 완전히 "임의" 문자열에 더 많은 주의를 기울여야 합니다. 이러한 함수에 의해 생성된 새로운 값은 넓은 공간에 임의로 분산되므로 INSERT 및 일부 SELECT 문이 매우 느려질 수 있습니다. UUID 값이 저장되어 있는 경우 "-" 기호를 제거해야 합니다.

6.2 특수 유형 데이터

일부 유형의 데이터 웰은 기본 제공 유형과 직접적으로 일치하지 않습니다. 킬로초 정밀도가 낮은 타임스탬프가 한 예입니다. 또 다른 예는 1Pv4 주소입니다. 사람들은 종종 VARCHAR(15) 열을 사용하여 IP 주소를 저장합니다. 그러나 실제로는 문자열이 아닌 32비트 부호 없는 정수입니다. 소수점을 사용하여 주소를 4개 부분으로 나누어 표현한 것은 사람들이 읽기 쉽도록 하기 위한 것입니다. 따라서 IP 주소는 부호 없는 정수로 저장되어야 합니다. MySQL은 이 두 가지 표현 방법 간 변환을 위해 INET_ATON() 및 INET_NTOA() 함수를 제공합니다.

2. 테이블 구조 디자인

1. 패러다임과 안티 패러다임

완전 정규화된 것부터 완전히 비정규화된 것까지, 그리고 둘 사이의 절충안까지 주어진 데이터를 표현하는 방법에는 일반적으로 여러 가지가 있습니다. 정규화된 데이터베이스에서는 각 사실이 정확히 한 번 나타납니다. 대조적으로, 비정규화된 데이터베이스에서는 정보가 중복되어 여러 위치에 저장될 수 있습니다.

패러다임의 장점과 단점

성능 향상을 고려할 때 특히 쓰기 집약적인 시나리오에서는 스키마 디자인을 정규화하는 것이 권장되는 경우가 많습니다.

  • 정규화된 업데이트 작업은 일반적으로 비정규화된 업데이트 작업보다 빠릅니다.
  • 데이터가 잘 정규화되면 중복된 데이터가 거의 또는 전혀 없으므로 수정해야 하는 데이터가 줄어듭니다.
  • 정규화된 테이블은 일반적으로 더 작고 메모리에 더 적합하므로 작업이 더 빠르게 수행됩니다.
  • 중복 데이터가 적다는 것은 목록 데이터를 검색할 때 필요한 DISTINCT 또는 GROUP BY 문이 적다는 것을 의미합니다.

안티 패러다임의 장점과 단점

관련 테이블이 필요하지 않으므로 테이블이 인덱스를 사용하지 않더라도 대부분의 쿼리에 대한 최악의 시나리오는 전체 테이블 스캔입니다. 이는 임의 I/0이 방지되므로 데이터가 메모리보다 큰 경우 연관보다 훨씬 빠를 수 있습니다.

개별 테이블에서도 보다 효율적인 인덱싱 전략을 사용할 수 있습니다.

정규화와 비정규화 혼합

실제 애플리케이션에서는 혼합이 필요한 경우가 많으며 부분적으로 정규화된 스키마, 캐시 테이블 및 기타 기술이 사용될 수 있습니다.

성능 우선순위와 같은 중복 필드를 테이블에 적절하게 추가하지만 복잡성이 증가합니다. 테이블 조인 쿼리를 피할 수 있습니다.

데이터베이스 패러다임에 쉽고 친숙함

<br> 첫 번째 정규형(1NF): 필드 값은 원자적이며 분할될 수 없습니다(모든 관계형 데이터베이스 시스템은 첫 번째 정규형을 충족함).<br> 예: 이름 필드에서 성과 이름이 전체인 경우 성과 이름이 구별되는 경우 두 개의 독립적인 필드를 설정해야 합니다.

두 번째 정규형(2NF): 테이블에는 기본 키가 있어야 합니다. 즉, 각 데이터 행을 고유하게 구별할 수 있습니다.
참고: 첫 번째 정규 형식이 먼저 충족되어야 합니다.

제3정규형(3NF): 테이블은 다른 관련 테이블의 키가 아닌 필드에 대한 정보를 포함할 수 없습니다. 즉, 데이터 테이블은 중복 필드를 가질 수 없습니다.
참고: 두 번째 정규형이 먼저 충족되어야 합니다.

2. 테이블 필드가 덜 정교해졌습니다.

  • I/O 효율성
  • 필드를 쉽게 분리하고 유지 관리할 수 있습니다
  • 싱글 테이블 1G 볼륨 500W 행 평가
  • 한 줄은 200Byte를 초과할 수 없습니다
  • 단일 테이블에 INT 필드는 50개 이하입니다
  • 단일 테이블에는 20개 이상의 CHAR(10) 필드를 사용할 수 없습니다
  • 한 테이블의 필드 수는 20개 이내로 조절하는 것이 좋습니다
  • TEXT/BLOB 분할, TEXT 유형의 처리 성능은 VARCHAR보다 훨씬 낮으므로 하드 디스크 임시 테이블 생성으로 인해 더 많은 공간이 낭비됩니다.

위 내용은 MySQL 고성능 테이블을 설계하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 Linux就该这么学에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Linux 관리자의 급여는 무엇입니까?Linux 관리자의 급여는 무엇입니까?Apr 17, 2025 am 12:24 AM

Linux 관리자의 평균 연봉은 미국에서 $ 75,000 ~ $ 95,000, 유럽에서는 40,000 유로에서 60,000 유로입니다. 급여를 늘리려면 다음과 같이 할 수 있습니다. 1. 클라우드 컴퓨팅 및 컨테이너 기술과 같은 새로운 기술을 지속적으로 배울 수 있습니다. 2. 프로젝트 경험을 축적하고 포트폴리오를 설정합니다. 3. 전문 네트워크를 설정하고 네트워크를 확장하십시오.

Linux의 주요 목적은 무엇입니까?Linux의 주요 목적은 무엇입니까?Apr 16, 2025 am 12:19 AM

Linux의 주요 용도에는 다음이 포함됩니다. 1. 서버 운영 체제, 2. 임베디드 시스템, 3. 데스크탑 운영 체제, 4. 개발 및 테스트 환경. Linux는이 분야에서 뛰어나 안정성, 보안 및 효율적인 개발 도구를 제공합니다.

인터넷은 Linux에서 실행됩니까?인터넷은 Linux에서 실행됩니까?Apr 14, 2025 am 12:03 AM

인터넷은 단일 운영 체제에 의존하지 않지만 Linux는 이에 중요한 역할을합니다. Linux는 서버 및 네트워크 장치에서 널리 사용되며 안정성, 보안 및 확장 성으로 인기가 있습니다.

Linux 운영이란 무엇입니까?Linux 운영이란 무엇입니까?Apr 13, 2025 am 12:20 AM

Linux 운영 체제의 핵심은 명령 줄 인터페이스이며 명령 줄을 통해 다양한 작업을 수행 할 수 있습니다. 1. 파일 및 디렉토리 작업 LS, CD, MKDIR, RM 및 기타 명령을 사용하여 파일 및 디렉토리를 관리합니다. 2. 사용자 및 권한 관리는 UserAdd, Passwd, CHMOD 및 기타 명령을 통해 시스템 보안 및 리소스 할당을 보장합니다. 3. 프로세스 관리는 PS, Kill 및 기타 명령을 사용하여 시스템 프로세스를 모니터링하고 제어합니다. 4. 네트워크 운영에는 Ping, Ifconfig, SSH 및 기타 명령이 포함되어 있으며 네트워크 연결을 구성하고 관리합니다. 5. 시스템 모니터링 및 유지 관리 Top, DF, Du와 같은 명령을 사용하여 시스템의 작동 상태 및 리소스 사용을 이해합니다.

Linux 별칭을 사용하여 사용자 정의 명령 바로 가기로 생산성을 높이십시오Linux 별칭을 사용하여 사용자 정의 명령 바로 가기로 생산성을 높이십시오Apr 12, 2025 am 11:43 AM

소개 Linux는 유연성과 효율성으로 인해 개발자, 시스템 관리자 및 전원 사용자가 선호하는 강력한 운영 체제입니다. 그러나 길고 복잡한 명령을 자주 사용하는 것은 지루하고 응급실이 될 수 있습니다.

Linux는 실제로 좋은 것은 무엇입니까?Linux는 실제로 좋은 것은 무엇입니까?Apr 12, 2025 am 12:20 AM

Linux는 서버, 개발 환경 및 임베디드 시스템에 적합합니다. 1. 서버 운영 체제로서 Linux는 안정적이고 효율적이며 종종 고 대전성 애플리케이션을 배포하는 데 사용됩니다. 2. 개발 환경으로서 Linux는 효율적인 명령 줄 도구 및 패키지 관리 시스템을 제공하여 개발 효율성을 향상시킵니다. 3. 임베디드 시스템에서 Linux는 가볍고 사용자 정의 가능하며 자원이 제한된 환경에 적합합니다.

Linux에서 윤리적 해킹을 마스터하기위한 필수 도구 및 프레임 워크Linux에서 윤리적 해킹을 마스터하기위한 필수 도구 및 프레임 워크Apr 11, 2025 am 09:11 AM

소개 : Linux 기반의 윤리적 해킹으로 디지털 프론티어 보안 점점 더 상호 연결된 세상에서 사이버 보안이 가장 중요합니다. 윤리적 해킹 및 침투 테스트는 취약점을 적극적으로 식별하고 완화하는 데 필수적입니다.

Linux 기본 사항을 배우는 방법?Linux 기본 사항을 배우는 방법?Apr 10, 2025 am 09:32 AM

기본 Linux 학습 방법은 다음과 같습니다. 1. 파일 시스템 및 명령 줄 인터페이스 이해, 2. LS, CD, MKDIR, 3. 파일 생성 및 편집과 같은 파일 작업 배우기, 4. 파이프 라인 및 GREP 명령과 같은 고급 사용법, 5. 연습 및 탐색을 통해 지속적으로 기술을 향상시킵니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경