MySQL 구문 분석 테이블 잠금
이 기사에서는 테이블 잠금에 대한 관련 구문 분석을 주로 소개하는 mysql에 대한 관련 지식을 제공합니다. MySQL을 사용하면 클라이언트 세션이 특정 기간 내에 다른 세션에 액세스하지 못하도록 명시적으로 테이블 잠금을 획득할 수 있습니다. 아래의 동일한 표가 모든 사람에게 도움이 되기를 바랍니다.
추천 학습: mysql 비디오 튜토리얼
MySQL 테이블 잠금
잠금은 테이블과 관련된 플래그입니다. MySQL을 사용하면 클라이언트 세션이 명시적으로 테이블 잠금을 획득하여 다른 세션이 특정 기간 동안 동일한 테이블에 액세스하는 것을 방지할 수 있습니다. 클라이언트 세션은 자체 테이블 잠금만 획득하거나 해제할 수 있습니다. 다른 세션에 대한 테이블 잠금을 획득하거나 해제할 수 없습니다.
CREATE TABLE tbl ( id INT NOT NULL AUTO_INCREMENT, col INT NOT NULL, PRIMARY KEY (id)) Engine = InnoDB;
LOCK 및 UNLOCK TABLES 구문
다음 문은 명시적으로 테이블 잠금을 획득합니다.
LOCK TABLES table_name [READ | WRITE]
테이블을 잠그려면 LOCK TABLES 키워드 뒤에 해당 이름을 지정합니다. 또한 READ 또는 WRITE 등의 잠금 유형을 지정할 수 있습니다.
테이블에 대한 잠금을 해제하려면 다음 명령문을 사용하세요.
UNLOCK TABLES;
Read lock
READ 잠금의 특징은 다음과 같습니다.
- READ는 여러 세션을 통해 동시에 테이블에 대한 잠금을 획득할 수 있습니다. 또한 다른 세션은 잠금을 획득하지 않고도 테이블에서 데이터를 읽을 수 있습니다.
- READ 잠금을 보유한 세션은 테이블의 데이터를 읽을 수만 있고 쓸 수는 없습니다. 또한 READ가 잠금을 해제할 때까지 다른 세션이 테이블에 데이터를 쓸 수 없습니다. 다른 세션의 쓰기 작업은 READ 잠금이 해제될 때까지 대기 상태로 들어갑니다.
- MySQL은 세션이 정상적으로 종료되거나 비정상적으로 종료되면 암시적으로 모든 잠금을 해제합니다. 이 기능은 WRITE 잠금과도 관련이 있습니다.
예:
첫 번째 세션에서 먼저 mysqldemo 데이터베이스에 연결하고 아래와 같이 CONNECTION_ID() 함수를 사용하여 현재 연결 ID를 가져옵니다.
SELECT CONNECTION_ID();
그런 다음 tbl에 새 연결 ID를 삽입합니다. 테이블 괜찮아.
INSERT INTO tbl(col) VALUES(10);
다음으로 tbl 테이블의 데이터를 쿼리합니다.
SELECT * FROM tbl;
그런 다음 잠금을 얻으려면 LOCK TABLE 문을 사용하세요.
LOCK TABLE tbl READ;
마지막으로 동일한 세션 내에서 tbl 테이블에 새 행을 삽입하려고 하면 오류 메시지가 표시됩니다.
INSERT INTO tbl(col) VALUES(11);
따라서 READ가 잠금을 획득하면 동일한 세션의 테이블에 데이터를 쓸 수 없습니다.
다른 세션의 잠금을 확인하세요.
먼저 mysqldemo에 연결하고 연결 ID를 확인합니다:
SELECT CONNECTION_ID();
그런 다음 tbl 테이블에서 데이터를 검색합니다:
SELECT * FROM tbl;
다음으로 tbl 테이블에 새 행을 삽입합니다:
INSERT INTO tbl(col) VALUES(20);
second 첫 번째 세션 READ가 tbl 테이블에 대한 잠금을 획득했지만 아직 해제하지 않았기 때문에 각 세션의 삽입 작업은 대기 상태입니다.
자세한 내용은 SHOW PROCESSLIST에서 확인하실 수 있습니다.
SHOW PROCESSLIST;
이후 첫 번째 세션으로 돌아가서 UNLOCK TABLES 문을 사용하여 잠금을 해제합니다. READ가 첫 번째 세션에서 잠금을 해제한 후 INSERT는 두 번째 세션에서 작업을 수행합니다.
unlock tables;
마지막으로 tbl 테이블의 데이터를 확인하여 두 번째 세션의 INSERT 작업이 실제로 실행되는지 확인합니다.
SELECT * FROM tbl;
WRITE LOCK
WRITE 잠금에는 다음과 같은 특징이 있습니다.
- 테이블 잠금을 보유하는 유일한 세션은 테이블에서 데이터를 읽고 쓸 수 있습니다.
- 다른 세션은 WRITE 잠금이 해제될 때까지 테이블에서 데이터를 읽고 쓸 수 없습니다.
먼저 WRITE는 첫 번째 세션에서 잠금을 가져옵니다.
LOCK TABLE tbl WRITE;
그런 다음 tbl 테이블
INSERT INTO tbl(col) VALUES(11);
에 새 행을 삽입하면 작동합니다.
다음으로 tbl 테이블에서 데이터를 읽습니다.
SELECT * FROM tbl;
그것도 작동합니다.
이후 두 번째 세션부터 데이터 쓰기 및 읽기를 시도해 보세요.
INSERT INTO tbl(col) VALUES(21); SELECT * FROM tbl;
最后,从第一个会话中释放锁定。
UNLOCK TABLES;
看到第二个会话中的所有待处理操作都已执行,下图说明了结果:
读锁与写锁
- 读锁是“共享”锁,它可以防止正在获取写锁,但不能锁定其他读锁。
- 写锁是“独占”锁,可以防止任何其他类型的锁。
推荐学习:mysql视频教程
위 내용은 MySQL 구문 분석 테이블 잠금의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











MySQL은 설치가 간단하고 강력하며 데이터를 쉽게 관리하기 쉽기 때문에 초보자에게 적합합니다. 1. 다양한 운영 체제에 적합한 간단한 설치 및 구성. 2. 데이터베이스 및 테이블 작성, 삽입, 쿼리, 업데이트 및 삭제와 같은 기본 작업을 지원합니다. 3. 조인 작업 및 하위 쿼리와 같은 고급 기능을 제공합니다. 4. 인덱싱, 쿼리 최적화 및 테이블 파티셔닝을 통해 성능을 향상시킬 수 있습니다. 5. 데이터 보안 및 일관성을 보장하기위한 지원 백업, 복구 및 보안 조치.

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) 데이터베이스 및 테이블 작성 : CreateAbase 및 CreateTable 명령을 사용하십시오. 2) 기본 작업 : 삽입, 업데이트, 삭제 및 선택. 3) 고급 운영 : 가입, 하위 쿼리 및 거래 처리. 4) 디버깅 기술 : 확인, 데이터 유형 및 권한을 확인하십시오. 5) 최적화 제안 : 인덱스 사용, 선택을 피하고 거래를 사용하십시오.

다음 단계를 통해 phpmyadmin을 열 수 있습니다. 1. 웹 사이트 제어판에 로그인; 2. phpmyadmin 아이콘을 찾고 클릭하십시오. 3. MySQL 자격 증명을 입력하십시오. 4. "로그인"을 클릭하십시오.

Navicat Premium을 사용하여 데이터베이스 생성 : 데이터베이스 서버에 연결하고 연결 매개 변수를 입력하십시오. 서버를 마우스 오른쪽 버튼으로 클릭하고 데이터베이스 생성을 선택하십시오. 새 데이터베이스의 이름과 지정된 문자 세트 및 Collation의 이름을 입력하십시오. 새 데이터베이스에 연결하고 객체 브라우저에서 테이블을 만듭니다. 테이블을 마우스 오른쪽 버튼으로 클릭하고 데이터 삽입을 선택하여 데이터를 삽입하십시오.

MySQL 및 SQL은 개발자에게 필수적인 기술입니다. 1.MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템이며 SQL은 데이터베이스를 관리하고 작동하는 데 사용되는 표준 언어입니다. 2.MYSQL은 효율적인 데이터 저장 및 검색 기능을 통해 여러 스토리지 엔진을 지원하며 SQL은 간단한 문을 통해 복잡한 데이터 작업을 완료합니다. 3. 사용의 예에는 기본 쿼리 및 조건 별 필터링 및 정렬과 같은 고급 쿼리가 포함됩니다. 4. 일반적인 오류에는 구문 오류 및 성능 문제가 포함되며 SQL 문을 확인하고 설명 명령을 사용하여 최적화 할 수 있습니다. 5. 성능 최적화 기술에는 인덱스 사용, 전체 테이블 스캔 피하기, 조인 작업 최적화 및 코드 가독성 향상이 포함됩니다.

응용 프로그램을 열고 새로운 연결 (Ctrl n)을 선택하여 Navicat에서 새로운 MySQL 연결을 만들 수 있습니다. "MySQL"을 연결 유형으로 선택하십시오. 호스트 이름/IP 주소, 포트, 사용자 이름 및 비밀번호를 입력하십시오. (선택 사항) 고급 옵션을 구성합니다. 연결을 저장하고 연결 이름을 입력하십시오.

백업 또는 트랜잭션 롤백 메커니즘이없는 한 데이터베이스에서 직접 삭제 된 행 복구는 일반적으로 불가능합니다. 키 포인트 : 거래 롤백 : 트랜잭션이 데이터를 복구하기 전에 롤백을 실행합니다. 백업 : 데이터베이스의 일반 백업을 사용하여 데이터를 신속하게 복원 할 수 있습니다. 데이터베이스 스냅 샷 : 데이터베이스의 읽기 전용 사본을 작성하고 데이터를 실수로 삭제 한 후 데이터를 복원 할 수 있습니다. 주의해서 삭제 명령문을 사용하십시오. 실수로 데이터를 삭제하지 않도록 조건을주의 깊게 점검하십시오. WHERE 절을 사용하십시오 : 삭제할 데이터를 명시 적으로 지정하십시오. 테스트 환경 사용 : 삭제 작업을 수행하기 전에 테스트하십시오.

Redis는 단일 스레드 아키텍처를 사용하여 고성능, 단순성 및 일관성을 제공합니다. 동시성을 향상시키기 위해 I/O 멀티플렉싱, 이벤트 루프, 비 블로킹 I/O 및 공유 메모리를 사용하지만 동시성 제한 제한, 단일 고장 지점 및 쓰기 집약적 인 워크로드에 부적합한 제한이 있습니다.
