MySQL INSERT DELAYED

来源:http://www.cnblogs.com/chenmh/archive/2016/04/05/5355517.html
-Advertisement-
Play Games

INSERT DELAYED 語法 用於INSERT語句的DELAYED選項是MySQL相對於標準SQL的擴展。如果您的客戶端不能等待INSERT完成,則這個選項是非常有用的。當您使用MySQL進行日誌編寫時,這是非常常見的問題。您也可以定期運行SELECT和UPDATE語句,這些語句花費的時間較長 ...


INSERT DELAYED 語法

INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
    [INTO] tbl_name [(col_name,...)]
    VALUES ({expr | DEFAULT},...),(...),...
    [ ON DUPLICATE KEY UPDATE col_name=expr, ... ]
或:

INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE]
    [INTO] tbl_name
    SET col_name={expr | DEFAULT}, ...
    [ ON DUPLICATE KEY UPDATE col_name=expr, ... ]

 

用於INSERT語句的DELAYED選項是MySQL相對於標準SQL的擴展。如果您的客戶端不能等待INSERT完成,則這個選項是非常有用的。當您使用MySQL進行日誌編寫時,這是非常常見的問題。您也可以定期運行SELECT和UPDATE語句,這些語句花費的時間較長。

當一個客戶端使用INSERT DELAYED時,會立刻從伺服器處得到一個確定。並且行被排入隊列,當表沒有被其它線程使用時,此行被插入。

使用INSERT DELAYED的另一個重要的好處是,來自許多客戶端的插入被集中在一起,並被編寫入一個塊。這比執行許多獨立的插入要快很多。

使用DELAYED時有一些限制:

  1. INSERT DELAYED僅適用於MyISAM, MEMORY和ARCHIVE表。對於MyISAM表,如果在數據文件的中間沒有空閑的塊,則支持同時採用SELECT和INSERT語句。在這些情況下,基本不需要對MyISAM使用INSERT DELAYED。
  2. INSERT DELAYED應該僅用於指定值清單的INSERT語句。伺服器忽略用於INSERT DELAYED...SELECT語句的DELAYED。
  3. 伺服器忽略用於INSERT DELAYED...ON DUPLICATE UPDATE語句的DELAYED。
  4. 因為在行被插入前,語句立刻返回,所以您不能使用LAST_INSERT_ID()來獲取AUTO_INCREMENT值。AUTO_INCREMENT值可能由語句生成。
  5. 對於SELECT語句,DELAYED行不可見,直到這些行確實被插入了為止。
  6. DELAYED在從屬複製伺服器中被忽略了,因為DELAYED不會在從屬伺服器中產生與主伺服器不一樣的數據。

註意,目前在隊列中的各行只保存在存儲器中,直到它們被插入到表中為止。這意味著,如果您強行中止了mysqld(例如,使用kill -9)或者如果mysqld意外停止,則所有沒有被寫入磁碟的行都會丟失。

以下詳細描述了當您對INSERT或REPLACE使用DELAYED選項時會發生什麼情況。在這些描述中,“線程”指的是已接受了一個INSERT DELAYED語句的線程,“管理程式”指的是為某個特定的表處理所有INSERT DELAYED語句的線程。

  1. 當一個線程對一個表執行DELAYED語句時,會創建出一個管理程式線程(如果原來不存在),對用於本表的所有DELAYED語句進行處理。
  2. 線程會檢查是否管理程式以前已獲取了DELAYED鎖定;如果沒有獲取,則告知管理程式線程進行此項操作。即使其它線程對錶有READ或WRITE鎖定,也可以獲得DELAYED鎖定。但是管理程式會等待所有的ALTER TABLE鎖定或FLUSH TABLE鎖定,以確保表的結構是最新的。
  3. 線程執行INSERT語句,但不是把行寫入表中,而是把最終行的拷貝放入一個由管理程式線程管理的隊列中。線程會提示出現語法錯誤,這些錯誤會被報告到客戶端中。
  4. 因為在插入操作之前,INSERT返回已經完成,所以客戶端不能從伺服器處獲取重覆記錄的數目,也不能獲取生成的行的AUTO_INCREMENT值。(如果您使用C API,則出於同樣的原因,mysql_info()函數不會返回任何有意義的東西。)
  5. 當行被插入表中時,二進位日誌被管理程式線程更新。在多行插入情況下,當第一行被插入時,二進位日誌被更新。
  6. 每次delayed_insert_limit行被編寫時,管理程式會檢查是否有SELECT語句仍然未執行。如果有,則會在繼續運行前,讓這些語句先執行。
  7. 當管理程式的隊列中沒有多餘的行時,表被解鎖。如果在delayed_insert_timeout時間內,沒有接收到新的INSERT DELAYED語句,則管理程式中止。
  8. 如果在某個特定的管理程式隊列中,有超過delayed_queue_size的行未被執行,則申請INSERT DELAYED的線程會等待,直到隊列中出現空間為止。這麼做可以確保mysqld不會把所有的存儲器都用於被延遲的存儲隊列。
  9. 管理程式線程會顯示在MySQL進程清單中,其命令列中包含delayed_insert。如果您執行一個FLUSH TABLES語句或使用KILL thread_id進行刪除,則會刪除此線程。不過,在退出前,線程會首先把所有排入隊列的行存儲到表中。在這期間,該線程不會從其它線程處接受任何新的INSERT語句。如果您在此之後執行一個INSERT DELAYED語句,則會創建出一個新的管理程式線程。

註意,如果有一個INSERT DELAYED管理程式正在運行,則這意味著INSERT DELAYED語句比常規的INSERT語句具有更高的優先權。其它更新語句必須等待,直到INSERT DELAYED語句隊列都運行完畢,或者管理程式線程被中止(使用KILL thread_id),或者執行了一個FLUSH TABLES時為止。

以下狀態變數提供了有關INSERT DELAYED語句的信息:

狀態變數

意義

Delayed_insert_threads

管理程式線程的數目

Delayed_writes

使用INSERT DELAYED寫入的行的數目

Not_flushed_delayed_rows

等待被寫入的行的數目

您可以通過發送一個SHOW STATUS語句,或者執行一個mysqladmin extended-status命令,來閱覽這些變數。

註意,當沒有使用表時,INSERT DELAYED比常規的INSERT要慢。對於伺服器來說,為每個含有延遲行的表操縱一個獨立的線程,也是一個額外的系統開銷。這意味著只有當您確認您需要時,才應使用INSERT DELAYED。

 

文章轉載來自:http://dev.mysql.com/doc/refman/5.6/en/insert-delayed.html


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

-Advertisement-
Play Games
更多相關文章
  • 如果只導出表的結構(建表語句),不導出表的數據,可用Tools--Export User Objects 選中要導出的表,設置好導出的路徑和各個參數後,點擊Export就OK PS:這種方式只能導出屬於這個用戶的表,其他用戶的表不能導出,建議用命令行導出(exp, imp) 如果想將表結構,表的數據 ...
  • 在知乎上看到這樣一個問題: MySQL 查詢 select * from table where id in (幾百或幾千個 id) 如何提高效率?修改 MySQL 查詢 select * from table where id in (幾百或幾千個 id) 如何提高效率?修改 電商網站,一個商品屬 ...
  • 在保密你的伺服器和數據,防備當前複雜的攻擊,SQL Server有你需要的一切。但在你能有效使用這些安全功能前,你需要理解你面對的威脅和一些基本的安全概念。這篇文章提供了基礎,因此你可以對SQL Server里的安全功能充分利用,不用在面對特定威脅,不能保護你數據的功能上浪費時間。 從讓人眼花繚亂的 ...
  • 1、SELECT基本語句: 2、檢索所有欄位,用"*"替換欄位名,這會導致效率低下 3、去除重覆項,“DISTINCT”作用於所有欄位 4、若檢索結果過多,可限定結果的條數 5、對檢索出的數據進行排序,ASC為升序,也為預設排序方式;DESC為降序。ORDER BY 語句一定是最後一條語句。如果不排 ...
  • 上節回顧 一、數據類型 什麼是數據類型? 數據類型是指列、存儲過程參數、表達式和局部變數的數據特征,它決定了數據的存儲格式,代表了不同的信息類型。 所謂數據類型,最直接的理解就是我們有些是存儲數字的,而數字當中,我們有時是要存儲為整數,有些可能要存儲為小數,還有的可能要存儲為日期、字元型,這就是我們 ...
  • MySQL的記錄長度 MySQL預設規定一條記錄最大的長度是65535位元組,所有的欄位加在一起所占的位元組數不能超過65535。但是MySQL中欄位的長度有的時使用位元組來規定int,有些欄位類型是使用字元個數來規定的。 1個漢字所占的是多少?根據字元編碼而定, latin1字元集1個字母占據1個位元組。 ...
  • AVG() 函數返回數值列的平均值。 SQL AVG() 語法 演示資料庫 在本教程中,我們將使用眾所周知的 Northwind 樣本資料庫。 下麵是選自 "Products" 表的數據: SQL AVG() 實例 下麵的 SQL 語句從 "Products" 表的 "Price" 列獲取平均值: ...
  • 資料庫的操作 創建一個資料庫 語法: create database 資料庫名【charset utf8】; 示例: 創建資料庫的本質:會在my.ini中的datadir配置選項指定的目錄中創建一個與資料庫同名的目錄。 在資料庫同名目錄中會存在一個db.opt文本文件示例: 說明: 字元集,是用於存 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...