久久机这里只有精品,国产69精品一区二区亚洲孕妇,91精品国产综合久久婷婷香蕉,午夜久久久久久电影

最新活動:電腦PC端+手機端+微網站+自適應網頁多模板選擇-建站388元起價!!!
當前位置:主頁 > 網站建設 > 如何提高MySQL中數據裝載效率建站知識

如何提高MySQL中數據裝載效率建站知識

時間:2023-05-24 07:05:24 閱讀: 文章分類: 網站建設 作者: 網站編輯員

導讀:1建站知識很多時候關心的是優化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優化它們并不總是直截了當。相對來說,將數據裝入數據庫是直截了當的。然而,也存在可用來網站seo優化培訓網站建設教程。

網站seo優化培訓網站建設教程很多時候關心的是優化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優化它們并不總是直截了當。相對來說seo網站優化培訓,將數據裝入數據庫是直截了當的。然而,也存在可用來改善數據裝載操作效率的策略,其基本原理如下:   成批裝載較單行裝載更快,因為在裝載每個記錄后,不需要刷新索引高速緩存;可在成批記錄裝入后才刷新。  網站建設教程; 在表無索引時裝載比索引后裝載更快。如果有索引,不僅必須增加記錄到數據文件,而且還要修改每個索引以反映增加了的新記錄。   較短的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 命令后,或延遲到該索引表關閉。相關網站seo優化培訓網站建設教程。

關鍵詞標簽: 標簽 SQL 效率

聲明: 本文由我的SEOUC技術文章主頁發布于:2023-05-24 ,文章如何提高MySQL中數據裝載效率建站知識主要講述效率,標簽,SQL網站建設源碼以及服務器配置搭建相關技術文章。轉載請保留鏈接: http://www.bifwcx.com/article/web_6256.html

我的IDC 網站建設技術SEOUC.COM
專注網站建設,SEO優化,小程序設計制作搭建開發定制網站等,數千家網站定制開發案例,網站推廣技術服務。
  • 5000+合作客服
  • 8年從業經驗
  • 150+覆蓋行業
  • 最新熱門源碼技術文章

    主站蜘蛛池模板: 新和县| 耿马| 临武县| 桓台县| 巩义市| 肇州县| 巴里| 丰县| 视频| 富源县| 华阴市| 丹阳市| 岳池县| 桦甸市| 婺源县| 平昌县| 阳高县| 安化县| 酒泉市| 二连浩特市| 改则县| 财经| 庄河市| 江阴市| 承德市| 准格尔旗| 高青县| 吉安县| 南丰县| 富锦市| 通河县| 临泉县| 浦东新区| 龙胜| 宣汉县| 鄂伦春自治旗| 司法| 沂南县| 介休市| 咸宁市| 寻甸|