>데이터 베이스 >MySQL 튜토리얼 >mysql 최적화 삽입 성능에 대한 관련 소개

mysql 최적화 삽입 성능에 대한 관련 소개

jacklove
jacklove원래의
2018-06-09 14:56:051750검색

mysql 삽입 문 구문

insert into `table`(`field1`,`field2`) values('value1','value2');

삽입 성능을 향상시키는 방법
1 여러 데이터 조각을 삽입하는 하나의 SQL 문

INSERT INTO `insert_table` (`uid`, `content`, `type`) VALUES ('userid_0', 'content_0', 0);
INSERT INTO `insert_table` (`uid`, `content`, `type`) VALUES ('userid_1', 'content_1', 1);

INSERT INTO `insert_table` (`uid`, `content`, `type`) VALUES ('userid_0', 'content_0', 0), ('userid_1', 'content_1', 1);

으로 작성할 수 있습니다. 2 . 트랜잭션 사용

START TRANSACTION;
INSERT INTO `insert_table` (`uid`, `content`, `type`) VALUES ('userid_0', 'content_0', 0);
INSERT INTO `insert_table` (`uid`, `content`, `type`) VALUES ('userid_1', 'content_1', 1);
...
COMMIT;

Note
1. SQL 문 길이에는 제한이 있으므로 SQL 문 병합 시 주의하시기 바랍니다. 길이 제한은 max_allowed_packet 구성 항목을 통해 수정할 수 있으며 기본값은 1M입니다.
2. 트랜잭션이 너무 크면 실행 효율성에 영향을 미치며, MySQL에는 innodb_log_buffer_size 구성 항목이 있으며, 이 값을 초과하면 디스크 데이터가 사용되므로 실행 효율성에 영향을 미칩니다.
트랜잭션에 대한 구성 항목 설명:
innodb_buffer_pool_size

Innodb를 사용하는 경우 이는 중요한 변수입니다. MyISAM과 비교하여 Innodb는 버퍼 크기에 더 민감합니다. MySIAM은 대용량 데이터에 기본 key_buffer_size를 사용하면 괜찮을 수 있지만, 대용량 데이터에 기본값을 사용하면 Innodb가 느리게 느껴집니다. Innodb의 버퍼 풀은 데이터와 인덱스를 캐시하므로 시스템 캐시를 위한 공간을 남겨둘 필요가 없습니다. Innodb만 사용하는 경우 이 값을 메모리의 70%-80%로 설정할 수 있습니다. key_buffer와 마찬가지로 데이터의 양이 상대적으로 적고 크게 증가하지 않는 경우 메모리 사용량을 늘리기 위해 이 값을 너무 높게 설정하지 마십시오.
innodb_additional_pool_size
적어도 운영 체제가 메모리를 합리적으로 할당할 수 있는 경우에는 이것의 효과가 그다지 명확하지 않습니다. 그러나 Innodb가 다른 용도로 할당할 메모리 양을 확인하려면 20M 이상으로 설정해야 할 수도 있습니다.
innodb_log_file_size
는 특히 많은 양의 데이터를 쓸 때 매우 중요합니다. 파일이 클수록 성능은 향상되지만 데이터베이스 복구에는 시간이 더 걸립니다. 저는 서버 공간에 따라 일반적으로 64M~512M을 사용합니다.
innodb_log_buffer_size
중간 쓰기 작업과 짧은 트랜잭션이 있는 대부분의 애플리케이션에는 기본값이 적합합니다. 자주 업데이트하거나 많은 Blob 데이터를 사용하는 경우 이 값을 늘려야 합니다. 하지만 너무 크면 메모리도 낭비하게 되는데, 1초에 한 번씩 항상 플러시(이 단어를 중국어로 뭐라고 하나요?)하기 때문에 요구량 1초를 초과하도록 설정할 필요가 없습니다. 일반적으로 8M-16M이면 충분합니다. 작은 응용 프로그램을 더 작게 설정할 수 있습니다.
innodb_flush_log_at_trx_commit
Innodb가 MyISAM보다 100배 느리다고 불평하시나요? 그렇다면 아마도 이 값을 조정하는 것을 잊었을 것입니다. 기본값 1은 트랜잭션 외부의 모든 트랜잭션 커밋 또는 명령이 하드 디스크에 로그를 기록해야 함(플러시)을 의미하며 이는 매우 시간이 많이 걸립니다. 특히 배터리 백업 캐시를 사용할 때 더욱 그렇습니다. 2로 설정하는 것은 많은 응용 프로그램, 특히 MyISAM 테이블에서 전송된 응용 프로그램에 적합합니다. 이는 하드 디스크에 쓰는 것이 아니라 시스템 캐시에 쓰는 것을 의미합니다. 로그는 여전히 매초 디스크에 플러시되므로 일반적으로 1~2초 이상의 업데이트가 손실되지 않습니다. 0으로 설정하면 속도가 빨라지지만 보안이 취약하여 MySQL이 중단되더라도 트랜잭션 데이터가 손실될 수 있습니다. 값 2는 전체 운영 체제에서만 작동합니다. 데이터는 정지된 경우에만 손실될 수 있습니다.
이 기사에서는 MySQL의 삽입 성능 최적화에 대한 관련 소개를 설명합니다. 자세한 내용은 PHP 중국어 웹사이트를 참조하세요.

관련 권장 사항:

php 사용 방법 일반적으로 사용되는 사용자 정의 방법

배타적 OR(XOR)을 사용하여 php를 통해 파일을 암호화/복호화하는 방법

변수 이름을 얻는 방법 php

위 내용은 mysql 최적화 삽입 성능에 대한 관련 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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