데이터 베이스 MySQL 튜토리얼 MYSQL的伪行级锁_MySQL

MYSQL的伪行级锁_MySQL

Jun 01, 2016 pm 01:41 PM
잠그다

bitsCN.com
MYSQL的伪行级锁 之前一直以为mysql的innodb引擎所支持的行级锁和oracle,postgresql是一样的,是对数据行上加锁。但其实是不一样的,理解不一样,对mysql的锁机制就容易产生误解。innodb的行级锁实际上是基于索引项来锁定的。以下是验证测试过程  一.数据准备mysql> use test;Database changedmysql> show create table t_kenyon /G*************************** 1. row ***************************       Table: t_kenyonCreate Table: CREATE TABLE `t_kenyon` (  `id` int(11) DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf81 row in set (0.00 sec) mysql> set autocommit = 0;Query OK, 0 rows affected (0.00 sec)   mysql> show variables like '%autocommit%';+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit    | OFF   |+---------------+-------+1 row in set (0.00 sec) mysql> select * from t_kenyon;+------+| id   |+------+|    1 ||  123 ||  789 ||  345 ||   78 ||   78 |+------+6 rows in set (0.00 sec)以上是测试表t_kenyon,设置提交方式为手动提交.  二.过程(开启两个session,分别设置autocommit=off)    1.session one updatemysql> update t_kenyon set id = 999 where id = 1;Query OK, 1 row affected (0.04 sec)Rows matched: 1  Changed: 1  Warnings: 0 mysql> select * from t_kenyon;+------+| id   |+------+|  999 ||  123 ||  789 ||  345 ||   78 ||   78 |+------+6 rows in set (0.00 sec)2.session two updatemysql> show variables like 'autocommit';+---------------+-------+| Variable_name | Value |+---------------+-------+| autocommit    | OFF   |+---------------+-------+1 row in set (0.00 sec)   mysql> select * from t_kenyon;+------+| id   |+------+|    1 ||  123 ||  789 ||  345 ||   78 ||   78 |+------+6 rows in set (0.00 sec) mysql> update t_kenyon set id = 88888 where id = 345;第二个session更新的值是345,但是也一直被阻塞,直到session1被rollback或者commit,如果session1未做回滚或者提交,session2中的该阻塞在超出mysql的锁时间限制时自动回滚,该参数为innodb_lock_wait_timeout,默认值50秒 现象如下ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction加索引后的测试 3.session one update mysql> create index ind_kenyon on t_kenyon(id);Query OK, 0 rows affected (28.58 sec)Records: 0  Duplicates: 0  Warnings: 0   mysql> update t_kenyon set id = 999 where id = 1;Query OK, 1 row affected (0.03 sec)Rows matched: 1  Changed: 1  Warnings: 0 mysql> select * from t_kenyon;+------+| id   |+------+|   78 ||   78 ||  123 ||  345 ||  789 ||  999 |+------+6 rows in set (0.00 sec)4.session two update mysql> select * from t_kenyon;+------+| id   |+------+|    1 ||   78 ||   78 ||  123 ||  345 ||  789 |+------+6 rows in set (0.00 sec)   mysql> update t_kenyon set id = 7777 where id = 345;Query OK, 1 row affected (0.03 sec)Rows matched: 1  Changed: 1  Warnings: 0 mysql> select * from t_kenyon;+------+| id   |+------+|    1 ||   78 ||   78 ||  123 ||  789 || 7777 |+------+6 rows in set (0.00 sec)执行计划mysql> explain select * from t_kenyon where id = 345 /G*************************** 1. row ***************************           id: 1      select_type: SIMPLE        table: t_kenyon         type: refpossible_keys: ind_kenyon          key: ind_kenyon      key_len: 5          ref: const         rows: 1        Extra: Using where; Using index1 row in set (0.00 sec)可以看到加了索引后,不同的数据更新并没有被阻塞,实现了真正意义上行锁 三.行级锁的扩展限制 参考:http:///database/201208/145888.html  作者 kenyon bitsCN.com

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

핫 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를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

잠긴 iPhone과 잠금 해제된 iPhone의 차이점은 무엇입니까? 자세한 소개: 잠긴 iPhone과 잠금 해제된 iPhone의 차이점 비교 잠긴 iPhone과 잠금 해제된 iPhone의 차이점은 무엇입니까? 자세한 소개: 잠긴 iPhone과 잠금 해제된 iPhone의 차이점 비교 Mar 28, 2024 pm 03:10 PM

Apple 휴대폰은 최근 사람들이 가장 많이 선택하는 휴대폰이지만, 온라인에서 잠겨 있는 Apple 휴대폰과 잠금 해제된 Apple 휴대폰의 차이점에 대해 토론하는 사람들을 종종 볼 수 있으며, 어떤 것을 사야 할지 얽혀 있습니다. 오늘 Chen Siqi는 잠긴 iPhone과 잠금 해제된 iPhone의 차이점을 공유하고 문제 해결에 도움을 드릴 것입니다. 사실 외관이나 기능면에서는 둘 사이에 큰 차이가 없습니다. 핵심은 가격과 용도에 있습니다. 잠금 버전과 잠금 해제 버전은 무엇인가요? 잠금 제한이 없는 iPhone은 이동통신사에 의해 제한되지 않으며 모든 이동통신사의 SIM 카드를 정상적으로 사용할 수 있다는 의미입니다. 잠금 버전은 네트워크 잠금 기능이 있어 지정된 사업자가 제공한 SIM 카드만 사용할 수 있고 다른 SIM 카드는 사용할 수 없음을 의미합니다. 실제로 언락된 애플폰은 모바일을 사용할 수 있고,

Oracle을 사용하여 테이블이 잠겨 있는지 쿼리하는 방법은 무엇입니까? Oracle을 사용하여 테이블이 잠겨 있는지 쿼리하는 방법은 무엇입니까? Mar 06, 2024 am 11:54 AM

제목: Oracle을 사용하여 테이블이 잠겨 있는지 쿼리하는 방법은 무엇입니까? Oracle 데이터베이스에서 테이블 잠금은 트랜잭션이 테이블에 쓰기 작업을 수행할 때 다른 트랜잭션이 테이블에 쓰기 작업을 수행하거나 테이블에 구조적 변경(예: 열 추가, 행 삭제)을 수행하려고 할 때 차단된다는 것을 의미합니다. , 등.). 실제 개발 과정에서 관련 문제를 더 잘 해결하고 처리하기 위해 테이블이 잠겨 있는지 쿼리해야 하는 경우가 종종 있습니다. 이 기사에서는 Oracle 문을 사용하여 테이블이 잠겨 있는지 쿼리하는 방법을 소개하고 특정 코드 예제를 제공합니다. 테이블이 잠겨 있는지 확인하려면

Python GIL(Global Interpreter Lock): 그 뒤에 있는 원리와 성능에 미치는 영향 파악 Python GIL(Global Interpreter Lock): 그 뒤에 있는 원리와 성능에 미치는 영향 파악 Feb 27, 2024 am 09:00 AM

pythonGIL(Global Interpreter Lock)은 Python의 중요한 메커니즘으로, 동시에 하나의 스레드만 Python 바이트코드를 실행할 수 있도록 제한합니다. Python의 메모리 관리 및 가비지 수집 메커니즘은 단일 스레드이기 때문에 이는 주로 Python 인터프리터의 안정성을 보장하기 위한 것입니다. 여러 스레드가 동시에 Python 바이트코드를 실행하도록 허용되면 메모리 손상이나 기타 예측할 수 없는 오류가 발생할 수 있습니다. GIL의 원리는 비교적 간단합니다. Python 인터프리터가 유지하는 잠금으로, 스레드가 Python 바이트코드를 실행할 때 GIL을 획득합니다. 다른 스레드가 Python 바이트코드를 실행하려면 GIL이 릴리스될 때까지 기다려야 합니다. GIL이 출시되면 다른

golang 함수의 잠금은 어떻게 구현됩니까? golang 함수의 잠금은 어떻게 구현됩니까? Jun 05, 2024 pm 12:39 PM

Go 언어의 잠금은 데이터 경쟁을 방지하기 위해 동기화된 동시 코드를 구현합니다. Mutex: Mutex 잠금은 동시에 하나의 고루틴만이 잠금을 획득하고 중요 섹션 제어에 사용되도록 보장합니다. RWMutex: 여러 고루틴이 동시에 데이터를 읽을 수 있도록 허용하지만 동시에 하나의 고루틴만 데이터를 쓸 수 있는 읽기-쓰기 잠금입니다. 공유 데이터를 자주 읽고 써야 하는 시나리오에 적합합니다.

Redis가 구현한 분산 잠금 성능 비교 Redis가 구현한 분산 잠금 성능 비교 Jun 20, 2023 pm 05:46 PM

인터넷 응용 프로그램이 점점 더 커지면서 분산 시스템이 점점 더 일반화되고 있습니다. 이러한 시스템에서는 분산 잠금이 필수 기능입니다. 분산 잠금에 대한 수요가 높기 때문에 다양한 구현 방법이 있습니다. 그중 Redis는 분산 잠금 구현에 널리 사용되는 인기 있는 도구입니다. 이 글에서는 Redis가 구현한 분산 잠금의 성능 비교를 살펴보겠습니다. 1. Redis의 기본 개념 Redis의 분산 잠금 성능을 논의하기 전에 Redis의 몇 가지 기본 개념을 이해해야 합니다.

Python 동시 프로그래밍의 잠금 및 동기화: 코드를 안전하고 안정적으로 유지 Python 동시 프로그래밍의 잠금 및 동기화: 코드를 안전하고 안정적으로 유지 Feb 19, 2024 pm 02:30 PM

동시 프로그래밍의 잠금 및 동기화 동시 프로그래밍에서는 여러 프로세스 또는 스레드가 동시에 실행되므로 리소스 경합 및 불일치 문제가 발생할 수 있습니다. 이러한 문제를 해결하려면 공유 리소스에 대한 액세스를 조정하는 잠금 및 동기화 메커니즘이 필요합니다. 잠금 개념 잠금은 한 번에 하나의 스레드나 프로세스만 공유 리소스에 액세스할 수 있도록 허용하는 메커니즘입니다. 하나의 스레드나 프로세스가 잠금을 획득하면 잠금이 해제될 때까지 다른 스레드나 프로세스가 리소스에 액세스하는 것이 차단됩니다. 잠금 유형 파이썬에는 여러 유형의 잠금이 있습니다. 뮤텍스 잠금(Mutex): 한 번에 하나의 스레드나 프로세스만 리소스에 액세스할 수 있도록 보장합니다. 조건 변수: 스레드나 프로세스가 특정 조건을 기다린 다음 잠금을 획득하도록 허용합니다. 읽기-쓰기 잠금: 여러 스레드가 동시에 리소스를 읽을 수 있지만 하나의 스레드만 리소스를 쓸 수 있습니다.

Golang 잠금의 기본 구현 메커니즘에 대한 심층 분석 Golang 잠금의 기본 구현 메커니즘에 대한 심층 분석 Dec 28, 2023 am 11:26 AM

Golang 잠금의 기본 구현 원리에 대한 자세한 설명에는 특정 코드 예제가 필요합니다. 개요: 동시 프로그래밍은 현대 소프트웨어 개발에서 매우 중요한 부분이며 잠금은 동시성 제어를 달성하기 위한 메커니즘입니다. Golang에서는 잠금 개념이 동시 프로그래밍에 널리 사용됩니다. 이 기사에서는 Golang 잠금의 기본 구현 원칙을 자세히 살펴보고 특정 코드 예제를 제공합니다. 뮤텍스 잠금(Mutex)의 기본 구현 원리 뮤텍스 잠금은 Golang에서 가장 일반적으로 사용되는 잠금 유형 중 하나입니다. 기본 데이터 구조인 sync.M을 사용합니다.

Golang의 캐시 잠금 사용법 및 모범 사례. Golang의 캐시 잠금 사용법 및 모범 사례. Jun 20, 2023 am 09:50 AM

Golang의 캐시 잠금 사용법 및 모범 사례. Golang의 캐시 잠금은 동시성이 높은 환경에서 실행 효율성을 향상시키는 데 사용되는 방법입니다. 동시 환경에서는 여러 고루틴이 동시에 동일한 데이터에 액세스할 수 있으며, 이로 인해 잠금 경쟁 및 데이터 경쟁과 같은 문제가 발생할 수 있습니다. 캐시 잠금은 동시 액세스를 방지하여 데이터 무결성과 일관성을 보장하기 위해 공유 데이터 저장소를 관리하는 메커니즘입니다. 이 기사에서는 Golang의 캐시 잠금 사용법과 모범 사례에 중점을 둘 것입니다. 1.골

See all articles