程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 進步MySQL中數據裝載效力

進步MySQL中數據裝載效力

編輯:MySQL綜合教程

進步MySQL中數據裝載效力。本站提示廣大學習愛好者:(進步MySQL中數據裝載效力)文章只能為提供參考,不一定能成為您想要的結果。以下是進步MySQL中數據裝載效力正文


絕對來講,將數據裝入數據庫是直接了當的。但是,也存在可用來改良數據裝載操作效力的戰略,其根本道理以下:

成批裝載較單行裝載更快,由於在裝載每一個記載後,不須要刷新索引高速緩存;可在成批記載裝入後才刷新。

在表無索引古裝載比索引後裝載更快。假如有索引,不只必需增長記載到數據文件,並且還要修正每一個索引以反應增長了的新記載。

較短的SQL 語句比擬長的SQL 語句要快,由於它們觸及辦事器方的剖析較少,並且還由於將它們經由過程收集從客戶機發送到辦事器更快。這些身分中有一些仿佛眇乎小哉(特殊是最初一個身分),但假如要裝載年夜量的數據,即便是很小的身分也會發生很年夜的分歧成果。我們可以應用上述的普通道理推導出幾個關於若何最快地裝載數據的現實結論:

LOAD DATA(包含其一切情勢)比INSERT 效力高,由於其成批裝載行。索引刷新較少,而且辦事器只需剖析息爭釋一條語句而不是幾條語句。

LOAD DATA 比LOAD DATA LOCAL 效力更高。應用LOAD DATA,文件必需定位在辦事器上,並且必需具有FILE 權限,但辦事器可從磁盤直接讀取文件。應用LOAD DATA LOCAL,客戶機讀取文件並將其經由過程收集發送給辦事器,如許做很慢。

假如必需應用INSERT,應當應用許可在單個語句中指定多行的情勢,例如:

可在語句中指定的行越多越好。如許會削減所需的語句數量,下降索引刷新量。假如應用mysqldump 生成數據庫備份文件,應當應用--extended-insert 選項,使轉儲文件包括多行INSERT 語句。還可使用- - o p t(優化) ,它啟用--extended-insert 選項。反之,應當防止應用mysqldump 的--complete-insert 選項;此選項會招致INSERT 語句為單行,履行時光更長,比不消--complete-insert 選項生成的語句須要更多的剖析。

應用緊縮了的客戶機/辦事器協定以削減收集數據流量。關於年夜多半MySQL客戶機,可以用--compress 敕令行選項來指定。它普通只用於較慢的收集,由於緊縮須要占用年夜量的處置器時光。

讓MySQL拔出缺省值;不要在INSERT 語句中指定將以隨意率性方法付與缺省值的列。均勻來講,如許做語句會更短,能削減經由過程收集傳送給辦事器的字符數。另外,語句包括的值較少,辦事器所停止的剖析和轉換就會較少。

假如表是索引的,則可應用批量拔出( LOAD DATA 或多行的INSERT 語句)來削減索引的開支。如許會最小化索引更新的影響,由於索引只須要在一切行處置過時才停止刷新,而不是在每行處置後就刷新。

假如須要將年夜量數據裝入一個新表,應當創立該表且在未索引古裝載,裝載數據後才創立索引,如許做較快。一次創立索引(而不是每行修正一次索引)較快。

假如在裝載之前刪除或禁用索引,裝入數據後再從新創立或啟用索引能夠使裝載更快。假如想對數據裝載應用刪除或禁用戰略,必定要做一些試驗,看如許做能否值得(假如將大批數據裝入一個年夜表中,重建和索引所消費的時光能夠比裝載數據的時光還要長)。

可用DROP INDEX 和CREATE INDEX 來刪除和重建索引。另外一種可供選擇的辦法是應用myisamchk 或isamchk 禁用和啟用索引。這須要在MySQL辦事器主機上有一個帳戶,並對表文件有寫入權。為了禁用表索引,可進入響應的數據庫目次,履行以下敕令之一:

對具有.MYI 擴大名的索引文件的MyISAM 表應用myisamchk,對具有.ISM 擴大名的索引文件的ISAM 表應用isamchk。在向表中裝入數據後,按以下激活索引:

假如決議應用索引禁用和激活,應當應用第13章中引見的表修復鎖定協定以阻攔辦事器同時更改鎖(固然此時纰謬表停止修復,但要對它像表修復進程一樣停止修正,是以須要應用雷同的鎖定協定)。

上述數據裝載道理也實用於與須要履行分歧操作的客戶機有關的固定查詢。例如,普通願望防止在頻仍更新的表上長時光運轉SELECT 查詢。長時光運轉SELECT 查詢會發生年夜量爭用,並下降寫入法式的機能。一種能夠的處理辦法為,假如履行寫入的重要是INSERT 操作,那末先將記載存入一個暫時表,然後按期地將這些記載參加主表中。假如須要立刻拜訪新記載,這不是一個可行的辦法。但只需能在一個較短的時光內不拜訪它們,便可以應用這個辦法。應用暫時表有兩個方面的利益。起首,它削減了與主表上SELECT 查詢語句的爭用,是以,履行更快。其次,從暫時表將記載裝入主表的總時光較分離裝載記載的總時光少;響應的索引高速緩存只需在每一個批量裝載停止時停止刷新,而不是在每行裝載後刷新。這個戰略的一個運用是進入Web 辦事器的Web 頁拜訪MySQL數據庫。在此情況下,能夠沒有包管記載立刻進入主表的較高權限。

假如數據其實不完整是那種在體系非正常封閉事宜中拔出的單個記載,那末削減索引刷新的另外一戰略是應用MyISAM 表的DELAYED_KEY_WRITE 表創立選項(假如將MySQL用於某些數據錄入任務時能夠會湧現這類情形)。此選項使索引高速緩存只偶然刷新,而不是在每次拔出後都要刷新。

假如願望在辦事器規模內應用延遲索引刷新,只需應用--delayed-key-write 選項啟動mysqld 便可。在此情況下,索引塊寫操作延遲到必需刷新塊以便為其他索引值騰出空間為止,或延遲到履行了一個flush-tables 敕令後,或延遲到該索引表封閉。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved