SELECT VERSION(); +-----------+ | VERSION() | +-----------+ | 5.5.20 | +-----------+ 1 row in set (0.00 sec) CREATE TABLE test ( a IN" />
  • <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    mysql的INNODB引擎鎖的原理試驗_MySQL

    來源:懂視網 責編:小采 時間:2020-11-09 19:42:09
    文檔

    mysql的INNODB引擎鎖的原理試驗_MySQL

    mysql的INNODB引擎鎖的原理試驗_MySQL:mysql的INNODB引擎鎖的原理是怎樣的,來做個試驗。 mysql> SELECT VERSION(); +-----------+ | VERSION() | +-----------+ | 5.5.20 | +-----------+ 1 row in set (0.00 sec) CREATE TABLE test ( a IN
    推薦度:
    導讀mysql的INNODB引擎鎖的原理試驗_MySQL:mysql的INNODB引擎鎖的原理是怎樣的,來做個試驗。 mysql> SELECT VERSION(); +-----------+ | VERSION() | +-----------+ | 5.5.20 | +-----------+ 1 row in set (0.00 sec) CREATE TABLE test ( a IN

    mysql的INNODB引擎鎖的原理是怎樣的,來做個試驗。

    mysql> SELECT VERSION();

    +-----------+
    | VERSION() |
    +-----------+
    | 5.5.20 |
    +-----------+
    1 row in set (0.00 sec)

    CREATE TABLE test
    (
    a INT(5),
    b VARCHAR(10),
    c VARCHAR(10)
    );
    INSERT INTO test VALUES(1,'111','111');
    INSERT INTO test VALUES(2,'222','222');
    INSERT INTO test VALUES(3,'333','333');
    INSERT INTO test VALUES(4,'444','444');
    INSERT INTO test VALUES(5,'555','555');
    INSERT INTO test VALUES(6,'666','666');
    COMMIT;

    mysql> select * from test;
    +------+------+------+
    | a | b | c |
    +------+------+------+
    | 1 | 111 | 111 |
    | 2 | 222 | 222 |
    | 3 | 333 | 333 |
    | 4 | 444 | 444 |
    | 5 | 555 | 555 |
    | 6 | 666 | 666 |
    +------+------+------+
    6 rows in set (0.00 sec)

    在CMD窗口完成實驗,需要設置set autocommit=off;

    1.在沒有主鍵的情況下,修改不同的一條記錄
    session1:
    mysql> update test set b='111' where a=1;
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 1 Changed: 0 Warnings: 0

    session2:
    mysql> update test set b='222' where a=2;--先是hang住,過段時間后就報錯
    ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

    2.在沒有主鍵的情況下,新增一條數據,然后修改另一條數據
    session1:
    mysql> insert into test values(7,'777','777');
    Query OK, 1 row affected (0.00 sec)

    session2:
    mysql> update test set b='222' where a=2;--先是hang住,過段時間后就報錯
    ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

    3.在有主鍵的情況下,修改不同的一條記錄
    ALTER TABLE test ADD PRIMARY KEY(a);
    當有主鍵時沒有產生鎖全表的情況
    session1:
    mysql> update test set b='111' where a=1;
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 1 Changed: 0 Warnings: 0

    session2:
    mysql> update test set b='222' where a=2;
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 1 Changed: 0 Warnings: 0

    當有主鍵時修改同一條記錄,會hang住,說明就是行鎖
    session1:
    mysql> update test set b='111' where a=1;
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 1 Changed: 0 Warnings: 0
    session2:
    mysql> update test set b='111' where a=1;
    ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

    4.在有主鍵的情況下,insert和update
    session1:
    mysql> insert into test values(8,'888','888');
    Query OK, 1 row affected (0.00 sec)

    session2:
    mysql> update test set b='111' where a=1;
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 1 Changed: 0 Warnings: 0

    5.在沒有索引的情況下,修改不同的一條記錄
    session1:
    mysql> update test set c='111' where b='111';
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 1 Changed: 0 Warnings: 0

    session2:
    mysql> update test set c='222' where b='222';
    ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

    6.在有索引的情況下,修改不同的一條記錄
    CREATE INDEX ind_t_b ON test(b);
    session1:
    mysql> update test set c='111' where b='111';
    Query OK, 0 rows affected (0.00 sec)
    Rows matched: 1 Changed: 0 Warnings: 0

    session2:
    mysql> update test set c='222' where b='222';
    Query OK, 0 rows affected (0.01 sec)
    Rows matched: 1 Changed: 0 Warnings: 0

    總結:當用到了索引(同時我也測試了建了索引沒有用到的情況,還是行鎖),則是行鎖,否則鎖全表,沒有Oracle中的行鎖方便。

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    mysql的INNODB引擎鎖的原理試驗_MySQL

    mysql的INNODB引擎鎖的原理試驗_MySQL:mysql的INNODB引擎鎖的原理是怎樣的,來做個試驗。 mysql> SELECT VERSION(); +-----------+ | VERSION() | +-----------+ | 5.5.20 | +-----------+ 1 row in set (0.00 sec) CREATE TABLE test ( a IN
    推薦度:
    標簽: 原理 in 鎖定
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 成人国产一区二区三区精品| 亚洲国产精品无码专区影院 | 国产福利91精品一区二区三区| 国产成人无码精品一区在线观看| 久久婷婷国产综合精品| 国产精品网址在线观看你懂的| 精品国偷自产在线| 亚洲精品人成无码中文毛片 | 亚洲国产精品乱码一区二区| 国产午夜精品理论片久久| 四虎国产精品免费久久久| 国产国产精品人在线视| 久久亚洲美女精品国产精品| 日韩经典精品无码一区| 国产久爱免费精品视频| 老司机99精品99| 精品少妇一区二区三区视频| 国产精品无码无片在线观看| 无码精品久久久天天影视| 日本五区在线不卡精品| 久久93精品国产91久久综合| 国产成人精品福利网站在线观看 | 亚洲精品性视频| 国内精品免费在线观看| 国产成人精品电影在线观看| 国内精品久久久久影院优| 亚洲精品国偷自产在线| 亚洲无码日韩精品第一页| 亚洲午夜精品久久久久久浪潮| 欧美国产成人久久精品| 黑人巨大精品欧美一区二区| 国产精品.XX视频.XXTV| 999久久久国产精品| 97精品国产高清自在线看超 | 好吊妞视频精品| 久久国产精品99久久久久久老狼 | 精品人妻系列无码天堂| 精品国产乱码久久久久久1区2区| 久久99精品久久只有精品 | 桃花岛精品亚洲国产成人| 亚洲国产精品久久久久|