>데이터 베이스 >MySQL 튜토리얼 >잠금을 유발하지 않고 MySQL에서 SELECT 문을 어떻게 실행할 수 있습니까?

잠금을 유발하지 않고 MySQL에서 SELECT 문을 어떻게 실행할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-30 09:04:17598검색

How Can I Execute SELECT Statements in MySQL Without Causing Locks?

MySQL 쿼리로 잠금 방지

MySQL에서 특정 쿼리는 잠금을 유발하여 특히 쿼리되는 테이블이 자주 실행될 때 성능 문제로 이어질 수 있습니다. 수정되었습니다. 이 문제를 해결하기 위해 다음과 같은 질문이 제기됩니다. 잠금을 유도하지 않고 select 문을 실행할 수 있는 방법이 있습니까?

문제의 원래 쿼리:

SELECT COUNT(online.account_id) cnt from online;

병렬 이벤트로 인해 테이블을 잠급니다. 테이블도 수정합니다. 질문은 가능한 대안을 탐구합니다.

응답에서 언급된 잠재적인 해결책 중 하나는 트랜잭션 격리 수준을 READ-UNCOMMITTED로 설정하는 것입니다. 그러나 이 접근 방식은 STATEMENT 모드의 바이너리 로깅과 호환되지 않으므로 슬레이브 데이터베이스에는 적합하지 않습니다.

슬레이브 데이터베이스와 호환되는 대체 접근 방식은 다음 구문을 사용하는 것입니다.

SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED ;
SELECT * FROM TABLE_NAME ;
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ ;

이 방법은 select 문이 실행되는 동안 잠금을 효과적으로 비활성화합니다. 그러나 이렇게 하면 비결정적인 결과가 발생할 수 있다는 점에 유의하는 것이 중요합니다.

또 다른 제안은 다음 구문을 사용하는 것입니다.

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED ;
SELECT * FROM TABLE_NAME ;
COMMIT ;

이 옵션은 또한 작업 기간 동안 잠금을 비활성화합니다. select 문을 실행하고 격리 기간 동안 변경된 내용이 즉시 커밋되도록 합니다. 이 접근 방식은 이전 방법에 비해 성능에 영향을 미칠 수 있다는 점에 유의해야 합니다. 또한 격리 수준은 커밋 시 자동으로 재설정되므로 명시적으로 격리 수준을 REPEATABLE READ로 다시 설정할 필요가 없습니다.

이러한 접근 방식을 사용하면 MySQL에서 선택 쿼리를 수행할 때 잠김을 방지할 수 있습니다. 성능을 향상하고 경합을 줄입니다. 그러나 적절한 방법을 선택할 때 데이터 정확성과 일관성에 대한 잠재적인 균형과 영향을 고려하는 것이 중요합니다.

위 내용은 잠금을 유발하지 않고 MySQL에서 SELECT 문을 어떻게 실행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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