>데이터 베이스 >MySQL 튜토리얼 >MySQL 8.0.0 개발 마일스톤 버전 출시!_MySQL

MySQL 8.0.0 개발 마일스톤 버전 출시!_MySQL

WBOY
WBOY원래의
2016-10-09 08:33:421257검색

MySQL 개발팀은 지난 12일 MySQL 8.0.0 개발 마일스톤 버전(DMR) 출시를 발표했습니다! 어떤 사람들은 왜 MySQL이 5.x에서 8.0으로 뛰어올랐는지 놀랄 수도 있습니다. 실제로 MySQL 5.x 시리즈는 오라클에 인수되기 전 5.1부터 시작하여 수년간 5.5, 5.6, 5.7 등 인수 이후에도 5.x로 남아있습니다. 실제로 원래 릴리스 리듬을 따르면 5.6.x는 6.x, 5.7.x는 7.x라고 생각하면 됩니다. 따라서 버전 이름 지정 방법을 변경했습니다.

하지만 이번에 출시된 MySQL 8.0.0 개발 버전에는 여전히 눈에 띄는 점이 많습니다.

MySQL 8.0.0 주요 기능

MyISAM 스토리지 엔진과 완전히 분리된 트랜잭션 데이터 사전

실제로 InnoDB의 일부 테이블에 데이터 사전을 넣으면 더 이상 FRM, TRG 및 PAR 파일이 필요하지 않습니다! 이제 정보 스키마가 데이터 사전 테이블의 보기로 나타납니다. 원칙적으로 MyISAM 데이터 테이블 유형은 전혀 필요하지 않으며 모든 시스템 테이블을 InnoDB에 배치할 수 있습니다.

SQL 역할

역할은 권한의 모음입니다. 역할을 생성하고 사용자에게 역할을 부여 및 제거할 수 있습니다. 권한 관리에 편리합니다.

utf8mb4 문자 집합이 기본 문자 집합이 되며 유니코드 9를 지원합니다

기본 문자 집합은 latin1에서 utf8mb4로 변경되고, 기본 데이터 정렬은 latin1_swedish_ci에서 utf8mb4_800_ci_ai로 변경됩니다.

보이지 않는 색인

일부 인덱스는 SQL 최적화 프로그램에서 사용되지 않도록 보이지 않게 만들 수 있지만 백그라운드에서 계속 업데이트됩니다. 필요한 경우 언제든지 가시성을 복원할 수 있습니다.

바이너리 데이터에 대한 비트 연산 수행 가능

BIGINT에서 비트 연산을 수행할 수 있을 뿐만 아니라 8.0부터 [VAR]BINARY/[TINYMEDIUMLONG]BLOB에서도 비트 연산을 지원합니다.

IPv6 및 UUID로 향상된 작동

INET6_ATON() 및 INET6_NTOA()는 이제 INET6_ATON()이 VARBINARY(16) 데이터 유형(128비트)을 반환하므로 비트 작업을 수행할 수 있습니다. 세 가지 새로운 함수 UUID_TO_BIN(), BIN_TO_UUID() 및 IS_UUID()를 도입하여 UUID 작업이 개선되었습니다. MySQL에는 특별한 IPv6 및 UUID 데이터 유형이 없지만 VARBINARY(16) 데이터 유형으로 저장됩니다.

영구 전역 변수

SET PERSIST를 사용하면 다시 시작해도 유지되는 영구 전역 변수를 설정할 수 있습니다.

성능 데이터베이스 성능 스키마 개선

예를 들어, 더 빠른 검색이 가능하도록 성능 데이터베이스에 100개 이상의 인덱스가 추가되었습니다.

SQL 파서 리팩터링

SQL 분석기에 대한 지속적이고 점진적인 개선. 기존 파서는 구문의 복잡성과 하향식 파싱 접근 방식으로 인해 심각한 제한이 있어 유지 관리 및 확장이 어려웠습니다.

비용 모델

InnoDB 버퍼는 이제 주 메모리 캐시에 몇 개의 테이블과 인덱스가 있는지 추정할 수 있으며, 이를 통해 최적화 프로그램은 액세스 방법을 선택할 때 데이터를 메모리에 저장할 수 있는지 아니면 디스크에 저장해야 하는지 알 수 있습니다.

히스토그램

히스토그램을 이용하면 사용자나 DBA가 데이터 분포에 대한 통계를 작성할 수 있으며, 이는 쿼리 최적화에 활용되어 최적화된 쿼리 솔루션을 찾을 수 있습니다.

스캐닝 성능 향상

전체 테이블 쿼리와 범위 쿼리의 성능을 5~20% 향상할 수 있는 InnoDB 범위 쿼리의 성능을 개선했습니다.

BLOB 재구성

BLOB를 리팩토링하면 조각 읽기/업데이트 작업 속도가 빨라져 JSON 데이터 작업 속도가 빨라질 수 있습니다.

지속적인 자기증가 가치

InnoDB는 자동 증가 시퀀스의 최대값을 리두 로그에 유지합니다. 이 개선 사항은 매우 오래된 버그 #199도 수정합니다.

임시테이블

압축된 임시 테이블에 대한 지원을 제거하고 임시 테이블 메타데이터를 메모리에 저장합니다.

더 중요한 개선 사항과 세부 정보는 MySQL 8.0.0 릴리스 공지 [1] 및 [2]를 참조하세요.

다운로드

현재 8.0.0은 아직 개발 버전입니다. 최신 기능을 경험하고 테스트하려면 dev.mysql.com[3]에서 각 플랫폼에 대한 설치 패키지를 다운로드할 수 있습니다. 그러나 MySQL 소프트웨어 패키지는 점점 더 커지고 있으며 Linux 플랫폼의 바이너리 패키지는 거의 1GB에 이릅니다. 프로덕션 환경에서 사용하는 경우 8.0이 안정 버전으로 들어가기 전에 5.7 시리즈를 계속 사용하십시오. 최신 버전은 5.7.15 GA 버전으로, 용량이 600M에 불과합니다.

최신 소스 코드는 GitHub에 있습니다. 관심 있는 친구들이 확인해 볼 수 있습니다. 그 중 많은 부분이 중국 사람들의 기여입니다.

[1]: http://dev.mysql.com/doc/relnotes/mysql/8.0/en/

[2]: http://mysqlserverteam.com/the-mysql-8-0-0-milestone-release-is-available/

[3]: http://dev.mysql.com/downloads/mysql/

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.