MySQL中lock tables和unlock tables淺析

来源:http://www.cnblogs.com/kerrycode/archive/2017/06/12/6991502.html
-Advertisement-
Play Games

MySQL中lock tables和unlock tables淺析 在MySQL中提供了鎖定表(lock tables)和解鎖表(unlock tables)的語法功能,ORACLE與SQL Server資料庫當中沒有這種語法。相信剛接觸MySQL的人,都想詳細、深入的瞭解一下這個功能.下麵就儘量全... ...


MySQL中lock tables和unlock tables淺析

 

MySQL中提供了鎖定表(lock tables)和解鎖表(unlock tables)的語法功能,ORACLESQL Server資料庫當中沒有這種語法。相信剛接觸MySQL的人,都想詳細、深入的瞭解一下這個功能.下麵就儘量全面的解析、總結一下MySQLlock tablesunlock tables的功能,如有不足或不正確的地方,歡迎指點一二。

 

 

鎖定表的語法:

 

LOCK TABLES

tbl_name [AS alias] {READ [LOCAL] | [LOW_PRIORITY] WRITE}

[, tbl_name [AS alias] {READ [LOCAL] | [LOW_PRIORITY] WRITE}] ...

 

 

 LOCAL修飾符表示可以允許在其他會話中對在當前會話中獲取了READ鎖的的表執行插入。但是當保持鎖時,若使用Server外的會話來操縱資料庫則不能使用READ LOCAL。另外,對於InnoDB表,READ LOCALREAD相同。

 

The LOCAL modifier enables nonconflicting INSERT statements (concurrent inserts) by other sessions to execute while the lock is held. (See Section 8.11.3, “Concurrent Inserts”.) However, READ LOCAL cannot be used if you are going to manipulate the database using processes external to the server while you hold the lock. For InnoDB tables, READ LOCAL is the same as READ.

 

修飾符LOW_PRIORITY用於之前版本的MySQL,它會影響鎖定行為,但是從MySQL 5.6.5以後,這個修飾符已經被棄用。如果使用它則會產生警告。

 

 

[LOW_PRIORITY] WRITE lock:

 

The session that holds the lock can read and write the table.

 

Only the session that holds the lock can access the table. No other session can access it until the lock is released.

 

Lock requests for the table by other sessions block while the WRITE lock is held.

 

The LOW_PRIORITY modifier has no effect. In previous versions of MySQL, it affected locking behavior, but this is no longer true. As of MySQL 5.6.5, it is deprecated and its use produces a warning. Use WRITE without LOW_PRIORITY instead.

 

 

解鎖表的語法:

 

UNLOCK TABLES

 

 

LOCK TABLES為當前會話鎖定表。 UNLOCK TABLES釋放被當前會話持有的任何鎖。官方文檔13.3.5 LOCK TABLES and UNLOCK TABLES Syntax已經對LOCK TALESUNLOCK  TABLES做了不少介紹,下麵我們通過一些測試例子來深入的理解一下鎖表與解鎖表的相關知識點。我們先準備一下測試環境用的表和數據。

 

mysql> create table test( id int, name varchar(12));
Query OK, 0 rows affected (0.07 sec)
 
mysql> insert into test
    -> select 10001, 'kerry'   union all
    -> select 10002, 'richard' union all
    -> select 10003, 'jimmy' ;
Query OK, 3 rows affected (0.05 sec)
Records: 3  Duplicates: 0  Warnings: 0
 
mysql> 

 

當前會話(會話ID61)持有test表的READ鎖後,那麼當前會話只可以讀該表,而不能往表中寫入數據,否則就會報Table 'test' was locked with a READ lock and can't be updated這樣的錯誤。

 

mysql> select connection_id();
+-----------------+
| connection_id() |
+-----------------+
|              61 |
+-----------------+
1 row in set (0.00 sec)
 
mysql> show open tables where in_use >=1;
Empty set (0.00 sec)
 
mysql> lock tables test read;
Query OK, 0 rows affected (0.00 sec)
 
mysql> show open tables where in_use >=1;
+----------+-------+--------+-------------+
| Database | Table | In_use | Name_locked |
+----------+-------+--------+-------------+
| MyDB     | test  |      1 |           0 |
+----------+-------+--------+-------------+
1 row in set (0.01 sec)
 
mysql> select * from test;
+-------+---------+
| id    | name    |
+-------+---------+
| 10001 | kerry   |
| 10002 | richard |
| 10003 | jimmy   |
+-------+---------+
3 rows in set (0.00 sec)
 
mysql> insert into test
    -> values(10004, 'ken');
ERROR 1099 (HY000): Table 'test' was locked with a READ lock and can't be updated
mysql> 

 

 

clip_image001

 

 

另外,我們測試一下修飾符LOCAL的用途,如下所示:

 

mysql> create table test2( id int , name varchar(12)) engine=MyISAM;
Query OK, 0 rows affected (0.05 sec)
 
mysql> insert into test2
    -> select 1001, 'test';
Query OK, 1 row affected (0.00 sec)
Records: 1  Duplicates: 0  Warnings: 0
mysql> select connection_id();
	   

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.要實現的效果圖以及工程目錄結構: 先看看效果圖吧: 接著看看我們的工程的目錄結構: 2.實現流程: Step 1:寫下底部選項的一些資源文件 我們從圖上可以看到,我們底部的每一項點擊的時候都有不同的效果是吧! 我們是通過是否selected來判定的!我們要寫的資源文件有:首先是圖片,然後是文字, ...
  • SQL SERVER的表結構及索引轉換為MySQL的表結構及索引,其實在很多第三方工具中有提供,比如navicat、sqlyog等,但是,在處理某些數據類型、預設值及索引轉換的時候,總有些不盡人意並且需要安裝軟體,懶人開始想法子,所以基於SQL SERVER,寫了一個存儲過程,可以根據表名直接轉換為 ...
  • 之前一直有在關註微軟認證的一些消息,由於最新的SQL Server認證加入了2016的相關內容,導致課程資料需要大部分更新,但是微軟更新相對比較慢,並且經常改版,目前發現的最新的MCP Cert Path為2017年5月22日版。所以需要不定時翻閱相關站點查看最新情況,這裡把目前最新的情況述說一下, ...
  • 目錄 一、索引 二、索引類型 三、索引種類 四、操作索引 五、創建索引的時機 六、命中索引 七、其它註意事項 八、LIMIT分頁 九、執行計劃 十、慢查詢日誌 一、索引 MySQL索引的建立對於MySQL的高效運行是很重要的,索引可以大大提高MySQL的檢索速度。 打個比方,如果合理的設計且使用索引 ...
  • [20170611]關於數據塊地址的計算.txt--//如果資料庫出現一些問題,會在alert或者跟蹤文件,或者屏幕出現一些錯誤提示.例如:ORA-00600: internal error code, arguments: [2662], [3], [392066208], [3], [39206 ...
  • 1.什麼是資料庫? 俗稱數據的倉庫,方便管理數據的軟體(或程式) 2.MySQL入門 1.官網下載 2.安裝MySql 直接雙擊安裝即可,但註意安裝的目錄不可出現中文。 2.1驗證安裝是否成功 打開命令行-->輸入 "mysql -u root -p" 回車,輸入密碼-->回車 出現以下內容,即為成 ...
  • 介紹 物理故障、操作系統故障或 SQL Server 故障都可能導致兩個可用性副本之間的會話失敗。 可用性副本不會定期檢查 Sqlservr.exe 所依賴的組件來驗證這些組件是在正常運行還是已出現故障。 但對於某些類型的故障,受影響的組件將向 Sqlservr.exe 報告錯誤。 由另一個組件報告 ...
  • MariaDB資料庫管理系統是MySQL的一個分支,主要由開源社區在維護,採用GPL授權許可 MariaDB的目的是完全相容MySQL,包括API和命令行,使之能輕鬆成為MySQL的代替品。在存儲引擎方面,使用XtraDB(英語:XtraDB)來代替MySQL的InnoDB。 MariaDB由MyS ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...