日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

在DB2中提高INSERT性能的技巧(1)

瀏覽:339日期:2023-03-24 09:22:44
正在看的db2教程是:在DB2中提高INSERT性能的技巧(1)。

INSERT 處理過程概述

首先讓我們快速地看看插入一行時(shí)的處理步驟。這些步驟中的每一步都有優(yōu)化的潛力,對(duì)此我們?cè)诤竺鏁?huì)一一討論。

  1. 在客戶機(jī)準(zhǔn)備 語句。對(duì)于動(dòng)態(tài) SQL,在語句執(zhí)行前就要做這一步,此處的性能是很重要的;對(duì)于靜態(tài) SQL,這一步的性能實(shí)際上關(guān)系不大,因?yàn)檎Z句的準(zhǔn)備是事先完成的。
  2. 在客戶機(jī),將要插入的行的各個(gè) 列值組裝起來,發(fā)送到 DB2 服務(wù)器。
  3. DB2 服務(wù)器確定將這一行插入到哪一頁中。
  4. DB2 在 用于該頁的緩沖池中預(yù)留一個(gè)位置。如果 DB2 選定的是一個(gè)已有的頁,那么就需要讀磁盤;如果使用一個(gè)新頁,則要在表空間(如果是SMS,也就是系統(tǒng)管理存儲(chǔ)的表空間)中為該頁物理地分配空間。插入了新行的每一頁最后都要從緩沖池寫入到磁盤。
  5. 在目標(biāo)頁中對(duì)該行進(jìn)行格式化,并獲得該行上的一個(gè)X(exclusive,獨(dú)占的) 行鎖。
  6. 將反映該 insert 的一條記錄寫入到日志緩沖區(qū)中。
  7. 最后提交包含該 insert 的事務(wù),如果這時(shí)日志緩沖區(qū)中的記錄還沒有被寫入日志文件的話,則將這些記錄寫到日志文件中。
此外,還可能發(fā)生很多類型的附加處理,這取決于數(shù)據(jù)庫配置,例如,索引或觸發(fā)器的存在。這種額外的處理對(duì)于性能來說也是意義重大的,我們?cè)诤竺鏁?huì)討論到。

insert 的替代方案

在詳細(xì)討論 insert 的優(yōu)化之前,讓我們先考慮一下 insert 的兩種替代方案:load 和 import。import 實(shí)用程序?qū)嶋H上是 SQL INSERT 的一個(gè)前端,但它的某些功能對(duì)于您來說也是有用的。load 也有一些有用的額外功能,但是我們使用 load 而不使用 insert 的主要原因是可以提高性能。

load 直接格式化數(shù)據(jù)頁,而避免了由于插入導(dǎo)致的對(duì)每一行進(jìn)行處理的大部分開銷(例如,日志記錄在這里實(shí)際上是消除了)。而且,load 可以更好地利用多處理器機(jī)器上的并行性。在 V8 load 中有兩個(gè)新功能,它們對(duì)于 load 成為 insert 的替代方案有著特別的功效,這兩個(gè)功能是:從游標(biāo)裝載和從調(diào)用層接口(CLI)應(yīng)用程序裝載。

從游標(biāo)裝載


這種方法可用于應(yīng)用程序的程序代碼(通過 db2Load API),或用于 DB2 腳本。下面是后一種情況的一個(gè)例子:
declare staffcursor cursor forselect * from staff;
load from staffcursor of cursor insert into myschema.new_staff;

這兩行可以用下面一行替代:
insert into myschema.new_staff select * from staff
同等效的 INSERT ... SELECT 語句相比,從游標(biāo)裝載幾乎可以提高 20% 的性能。

從 CLI 裝載


這種方法顯然只限于調(diào)用層接口(CLI)應(yīng)用程序,但是它非常快。這種技巧非常類似于數(shù)組插入,DB2 附帶了這樣的示例,使用 load 時(shí)的速度是使用經(jīng)過完全優(yōu)化的數(shù)組插入時(shí)的兩倍,幾乎要比未經(jīng)優(yōu)化的數(shù)組插入快 10 倍。

所有 insert 可以改進(jìn)的地方

讓我們看看插入處理的一些必要步驟,以及我們可以用來優(yōu)化這些步驟的技巧。

1. 語句準(zhǔn)備


作為一條 SQL 語句,INSERT 語句在執(zhí)行之前必須由 DB2 進(jìn)行編譯。這一步驟可以自動(dòng)發(fā)生(例如在 CLP 中,或者在一次 CLI SQLExecDirect 調(diào)用中),也可以顯式地進(jìn)行(例如,通過一條 SQL Prepare、CLI SQLPrepare 或 JDBC prepareStatement 語句)。該編譯過程牽涉到授權(quán)檢查、優(yōu)化,以及將語句轉(zhuǎn)化為可執(zhí)行格式時(shí)所需的其他一些活動(dòng)。在編譯語句時(shí),語句的訪問計(jì)劃被存儲(chǔ)在包緩存中。

如果重復(fù)地執(zhí)行相同的 INSERT 語句,則該語句的訪問計(jì)劃(通常)會(huì)進(jìn)入到包緩存中,這樣就免除了編譯的開銷。然而,如果 insert 語句對(duì)于每一行有不同的值,那么每一條語句都將被看成是惟一的,必須單獨(dú)地進(jìn)行編譯。因此,將像下面這樣的重復(fù)語句:
insert into mytable values (1, "abc")
insert into mytable values (2, "def")

等等,
換成帶有參數(shù)標(biāo)記的語句,一次準(zhǔn)備,重復(fù)執(zhí)行,這樣做是十分可取的:
insert into mytable values (?, ?)

使用參數(shù)標(biāo)記可以讓一系列的 insert 的運(yùn)行速度提高數(shù)倍。(在靜態(tài) SQL 程序中使用主機(jī)變量也可以獲得類似的好處。)

2. 發(fā)送列值到服務(wù)器


可以歸為這一類的優(yōu)化技巧有好幾種。最重要的一種技巧是在每條 insert 語句中包括多行,這樣就可以避免對(duì)于每一行都進(jìn)行客戶機(jī)-服務(wù)器通信,同時(shí)也減少了 DB2 開銷。可用于多行插入的技巧有:

    [1] [2] 下一篇

標(biāo)簽: DB2
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
另类中文字幕国产精品| 综合欧美亚洲| 久久国产欧美日韩精品| 午夜欧美精品久久久久久久| 欧美日韩亚洲在线观看| 午夜久久免费观看| 欧洲激情综合| 亚洲欧美日韩精品一区二区| 久久福利影视| 日韩福利在线观看| 另类欧美日韩国产在线| 国产成人精品三级高清久久91 | 综合国产在线| 久久国产福利| 视频一区视频二区在线观看| 日本亚洲视频在线| 日韩一区二区三区四区五区| 日韩高清不卡一区二区| 精品欧美视频| 亚洲一区二区毛片| 国产精品手机在线播放| 麻豆国产一区| 欧美日韩中文一区二区| 日欧美一区二区| 国产成人调教视频在线观看| 亚洲深夜福利| 国产精品欧美一区二区三区不卡| 色偷偷偷在线视频播放| 亚洲精品在线二区| 国产一区二区三区四区五区传媒| 五月婷婷六月综合| 欧美亚洲综合视频| 美女高潮久久久| 夜夜精品视频| 日韩电影二区| 久久国内精品| aⅴ色国产欧美| 国产精品宾馆| 亚洲主播在线| 欧美三区四区| 精品在线网站观看| 四虎成人精品一区二区免费网站| 久久久一本精品| 国产剧情一区| 婷婷综合国产| 久久国产精品亚洲77777| 天堂а√在线最新版中文在线| 亚洲欧美网站| 欧美日韩中文字幕一区二区三区| 国产91在线精品| 欧美激情视频一区二区三区免费 | 免费高清在线一区| 欧美黄色一区| 欧美一级一区| 三级欧美在线一区| 激情婷婷综合| 精品在线播放| 九九在线精品| 好看不卡的中文字幕| 久久视频国产| 91成人精品视频| 欧美日韩国产传媒| 999国产精品永久免费视频app| 精品美女在线视频| 捆绑调教日本一区二区三区| 97国产精品| 日韩免费小视频| 91视频一区| 亚洲天堂一区二区| 99热精品久久| 好吊一区二区三区| 综合一区二区三区| 国产欧美91| 91亚洲国产成人久久精品| 欧美精品资源| 亚洲免费黄色| 日韩一二三区在线观看| 日韩精品中文字幕一区二区| 国产亚洲精品美女久久久久久久久久| 日韩高清电影免费| 欧美91在线| 亚洲精品少妇| 国产精品多人| 国产一区二区三区精品在线观看| 国产一区2区在线观看| 亚洲毛片在线免费| 日韩精品亚洲专区| 91福利精品在线观看| 免费一级欧美在线观看视频 | 日本不卡在线视频| 国产精品成人国产| 日韩激情精品| 国产精品宾馆| 麻豆精品国产91久久久久久| 国产精品亚洲欧美日韩一区在线| 亚洲有吗中文字幕| 影音先锋国产精品| 国户精品久久久久久久久久久不卡| 日韩精品乱码av一区二区| 欧美日韩亚洲国产精品| 日韩欧美另类中文字幕| 国产精品久久久一区二区| 国产第一亚洲| 午夜宅男久久久| 国产精品v日韩精品v欧美精品网站| 欧美激情一区| 国产手机视频一区二区| 日韩成人午夜精品| av高清一区| 四虎国产精品免费久久| 欧美国产中文高清| 国精品产品一区| 91久久久精品国产| 91福利精品在线观看| 日本精品不卡| 国产精品主播| 精品91久久久久| 欧美日一区二区在线观看| 91精品韩国| 国产日产一区| 热久久国产精品| 国产精品久久久久久久免费观看 | 久久精品毛片| 亚洲精品高潮| 99久久久久久中文字幕一区| 91国内精品| 视频在线在亚洲| 久久精品91| 国产一区二区三区天码| 国产视频久久| 免费视频一区二区| 女主播福利一区| 亚洲激情中文在线| 正在播放日韩精品| 精品国内亚洲2022精品成人| 国产激情欧美| 亚洲欧洲免费| 精精国产xxxx视频在线播放| 另类小说一区二区三区| 国产欧美啪啪| 欧美日韩亚洲一区三区| 国产精品网在线观看| 国产高清视频一区二区| 国产激情一区| 国产91在线播放精品| 欧美国产小视频| 肉色欧美久久久久久久免费看| 精品亚洲成人| 欧美二三四区| 国产亚洲毛片| 国产一精品一av一免费爽爽| 免费在线欧美黄色| 久久精品毛片| 成人自拍av| 亚洲一区中文| 欧美日本二区| 中文av在线全新| 黑丝一区二区三区| 日本va欧美va欧美va精品| 日韩一区精品字幕| 91欧美精品| 国产拍在线视频| 国产精品外国| 久久久久久色| 福利视频一区| 久久精品亚洲人成影院| 国产精品成久久久久| av综合电影网站| 日韩精品一区第一页| 青青草伊人久久| 亚洲国内精品| 日韩欧美精品一区二区综合视频| 日韩国产欧美视频| 91看片一区| 欧美精品三级在线| 亚洲成av人片一区二区密柚| 蜜桃av一区| 日韩免费久久| 国产精品最新自拍| 国产一区白浆| 国产成人77亚洲精品www| 国产一区视频在线观看免费| 合欧美一区二区三区| 日韩高清成人| 精品欧美日韩精品| 亚洲精品影院在线观看| 一区免费视频| 欧美日韩在线播放视频| 精品国产中文字幕第一页| 日韩二区三区四区| 老司机久久99久久精品播放免费| 日本蜜桃在线观看视频| 欧美黄色精品| 麻豆91精品视频| 久久中文在线| 久久中文精品| 欧美国产日韩电影| 五月激情久久| 香蕉人人精品| 欧美日韩视频|