最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題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關(guān)鍵字專題關(guān)鍵字專題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
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

MySQL改善數(shù)據(jù)裝載操作效率的策略

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-09 14:37:24
文檔

MySQL改善數(shù)據(jù)裝載操作效率的策略

MySQL改善數(shù)據(jù)裝載操作效率的策略:多時候關(guān)心的是優(yōu)化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優(yōu)化它們并不總是直截了當(dāng)。相對來說,將數(shù)據(jù)裝入數(shù)據(jù)庫是直截了當(dāng)?shù)?。然而,也存在可用來改善?shù)據(jù)裝載操作效率的策略,其基本原理如下: 成批裝載較單行裝載更快,因為在裝載每個記錄
推薦度:
導(dǎo)讀MySQL改善數(shù)據(jù)裝載操作效率的策略:多時候關(guān)心的是優(yōu)化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優(yōu)化它們并不總是直截了當(dāng)。相對來說,將數(shù)據(jù)裝入數(shù)據(jù)庫是直截了當(dāng)?shù)?。然而,也存在可用來改善?shù)據(jù)裝載操作效率的策略,其基本原理如下: 成批裝載較單行裝載更快,因為在裝載每個記錄

多時候關(guān)心的是優(yōu)化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優(yōu)化它們并不總是直截了當(dāng)。相對來說,將數(shù)據(jù)裝入數(shù)據(jù)庫是直截了當(dāng)?shù)?。然而,也存在可用來改善?shù)據(jù)裝載操作效率的策略,其基本原理如下: 成批裝載較單行裝載更快,因為在裝載每個記錄

多時候關(guān)心的是優(yōu)化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優(yōu)化它們并不總是直截了當(dāng)。相對來說,將數(shù)據(jù)裝入數(shù)據(jù)庫是直截了當(dāng)?shù)?。然而,也存在可用來改善?shù)據(jù)裝載操作效率的策略,其基本原理如下:

成批裝載較單行裝載更快,因為在裝載每個記錄后,不需要刷新索引高速緩存;可在成批記錄裝入后才刷新。

在表無索引時裝載比索引后裝載更快。如果有索引,不僅必須增加記錄到數(shù)據(jù)文件,而且還要修改每個索引以反映增加了的新記錄。

較短的SQL 語句比較長的SQL 語句要快,因為它們涉及服務(wù)器方的分析較少,而且還因為將它們通過網(wǎng)絡(luò)從客戶機發(fā)送到服務(wù)器更快。這些因素中有一些似乎微不足道(特別是最后一個因素),但如果要裝載大量的數(shù)據(jù),即使是很小的因素也會產(chǎn)生很大的不同結(jié)果。我們可以利用上述的一般原理推導(dǎo)出幾個關(guān)于如何最快地裝載數(shù)據(jù)的實際結(jié)論:

LOAD DATA(包括其所有形式)比INSERT 效率高,因為其成批裝載行。索引刷新較少,并且服務(wù)器只需分析和解釋一條語句而不是幾條語句。

LOAD DATA 比LOAD DATA LOCAL 效率更高。利用LOAD DATA,文件必須定位在服務(wù)器上,而且必須具有FILE 權(quán)限,但服務(wù)器可從磁盤直接讀取文件。利用LOAD DATA LOCAL,客戶機讀取文件并將其通過網(wǎng)絡(luò)發(fā)送給服務(wù)器,這樣做很慢。

如果必須使用INSERT,應(yīng)該利用允許在單個語句中指定多行的形式,例如:

可在語句中指定的行越多越好。這樣會減少所需的語句數(shù)目,降低索引刷新量。如果使用mysqldump 生成數(shù)據(jù)庫備份文件,應(yīng)該使用--extended-insert 選項,使轉(zhuǎn)儲文件包含多行INSERT 語句。還可以使用- - o p t(優(yōu)化) ,它啟用--extended-insert 選項。反之,應(yīng)該避免使用mysqldump 的--complete-insert 選項;此選項會導(dǎo)致INSERT 語句為單行,執(zhí)行時間更長,比不用--complete-insert 選項生成的語句需要更多的分析。

使用壓縮了的客戶機/服務(wù)器協(xié)議以減少網(wǎng)絡(luò)數(shù)據(jù)流量。對于大多數(shù)MySQL客戶機,可以用--compress 命令行選項來指定。它一般只用于較慢的網(wǎng)絡(luò),因為壓縮需要占用大量的處理器時間。

讓MySQL插入缺省值;不要在INSERT 語句中指定將以任意方式賦予缺省值的列。平均來說,這樣做語句會更短,能減少通過網(wǎng)絡(luò)傳送給服務(wù)器的字符數(shù)。此外,語句包含的值較少,服務(wù)器所進行的分析和轉(zhuǎn)換就會較少。

如果表是索引的,則可利用批量插入( LOAD DATA 或多行的INSERT 語句)來減少索引的開銷。這樣會最小化索引更新的影響,因為索引只需要在所有行處理過時才進行刷新,而不是在每行處理后就刷新。

如果需要將大量數(shù)據(jù)裝入一個新表,應(yīng)該創(chuàng)建該表且在未索引時裝載,裝載數(shù)據(jù)后才創(chuàng)建索引,這樣做較快。一次創(chuàng)建索引(而不是每行修改一次索引)較快。

如果在裝載之前刪除或禁用索引,裝入數(shù)據(jù)后再重新創(chuàng)建或啟用索引可能使裝載更快。如果想對數(shù)據(jù)裝載使用刪除或禁用策略,一定要做一些實驗,看這樣做是否值得(如果將少量數(shù)據(jù)裝入一個大表中,重建和索引所花費的時間可能比裝載數(shù)據(jù)的時間還要長)。

可用DROP INDEX 和CREATE INDEX 來刪除和重建索引。另一種可供選擇的方法是利用myisamchk 或isamchk 禁用和啟用索引。這需要在MySQL服務(wù)器主機上有一個帳戶,并對表文件有寫入權(quán)。為了禁用表索引,可進入相應(yīng)的數(shù)據(jù)庫目錄,執(zhí)行下列命令之一:

對具有.MYI 擴展名的索引文件的MyISAM 表使用myisamchk,對具有.ISM 擴展名的索引文件的ISAM 表使用isamchk。在向表中裝入數(shù)據(jù)后,按如下激活索引:

如果決定使用索引禁用和激活,應(yīng)該使用第13章中介紹的表修復(fù)鎖定協(xié)議以阻止服務(wù)器同時更改鎖(雖然此時不對表進行修復(fù),但要對它像表修復(fù)過程一樣進行修改,因此需要使用相同的鎖定協(xié)議)。

上述數(shù)據(jù)裝載原理也適用于與需要執(zhí)行不同操作的客戶機有關(guān)的固定查詢。例如,一般希望避免在頻繁更新的表上長時間運行SELECT 查詢。長時間運行SELECT 查詢會產(chǎn)生大量爭用,并降低寫入程序的性能。一種可能的解決方法為,如果執(zhí)行寫入的主要是INSERT 操作,那么先將記錄存入一個臨時表,然后定期地將這些記錄加入主表中。如果需要立即訪問新記錄,這不是一個可行的方法。但只要能在一個較短的時間內(nèi)不訪問它們,就可以使用這個方法。使用臨時表有兩個方面的好處。首先,它減少了與主表上SELECT 查詢語句的爭用,因此,執(zhí)行更快。其次,從臨時表將記錄裝入主表的總時間較分別裝載記錄的總時間少;相應(yīng)的索引高速緩存只需在每個批量裝載結(jié)束時進行刷新,而不是在每行裝載后刷新。這個策略的一個應(yīng)用是進入Web 服務(wù)器的Web 頁訪問MySQL數(shù)據(jù)庫。在此情形下,可能沒有保證記錄立即進入主表的較高權(quán)限。

如果數(shù)據(jù)并不完全是那種在系統(tǒng)非正常關(guān)閉事件中插入的單個記錄,那么減少索引刷新的另一策略是使用MyISAM 表的DELAYED_KEY_WRITE 表創(chuàng)建選項(如果將MySQL用于某些數(shù)據(jù)錄入工作時可能會出現(xiàn)這種情況)。此選項使索引高速緩存只偶爾刷新,而不是在每次插入后都要刷新。

如果希望在服務(wù)器范圍內(nèi)利用延遲索引刷新,只要利用--delayed-key-write 選項啟動mysqld 即可。在此情形下,索引塊寫操作延遲到必須刷新塊以便為其他索引值騰出空間為止,或延遲到執(zhí)行了一個flush-tables 命令后,或延遲到該索引表關(guān)閉。

(責(zé)任編輯:銘銘 mingming_ky@126.com TEL:(010)68476636)

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

文檔

MySQL改善數(shù)據(jù)裝載操作效率的策略

MySQL改善數(shù)據(jù)裝載操作效率的策略:多時候關(guān)心的是優(yōu)化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優(yōu)化它們并不總是直截了當(dāng)。相對來說,將數(shù)據(jù)裝入數(shù)據(jù)庫是直截了當(dāng)?shù)摹H欢?,也存在可用來改善?shù)據(jù)裝載操作效率的策略,其基本原理如下: 成批裝載較單行裝載更快,因為在裝載每個記錄
推薦度:
標(biāo)簽: 操作 數(shù)據(jù) 效率
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top