亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > DB2 > 正文

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

2020-01-31 14:52:57
字體:
來源:轉載
供稿:網友
正在看的db2教程是:在DB2中提高INSERT性能的技巧(1)。

INSERT 處理過程概述

首先讓我們快速地看看插入一行時的處理步驟。這些步驟中的每一步都有優化的潛力,對此我們在后面會一一討論。

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

insert 的替代方案

在詳細討論 insert 的優化之前,讓我們先考慮一下 insert 的兩種替代方案:load 和 import。import 實用程序實際上是 SQL INSERT 的一個前端,但它的某些功能對于您來說也是有用的。load 也有一些有用的額外功能,但是我們使用 load 而不使用 insert 的主要原因是可以提高性能。

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

從游標裝載


這種方法可用于應用程序的程序代碼(通過 db2Load API),或用于 DB2 腳本。下面是后一種情況的一個例子:
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 語句相比,從游標裝載幾乎可以提高 20% 的性能。

從 CLI 裝載


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

所有 insert 可以改進的地方

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

1. 語句準備


作為一條 SQL 語句,INSERT 語句在執行之前必須由 DB2 進行編譯。這一步驟可以自動發生(例如在 CLP 中,或者在一次 CLI SQLExecDirect 調用中),也可以顯式地進行(例如,通過一條 SQL Prepare、CLI SQLPrepare 或 JDBC prepareStatement 語句)。該編譯過程牽涉到授權檢查、優化,以及將語句轉化為可執行格式時所需的其他一些活動。在編譯語句時,語句的訪問計劃被存儲在包緩存中。

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

等等,
換成帶有參數標記的語句,一次準備,重復執行,這樣做是十分可取的:
insert into mytable values (?, ?)

使用參數標記可以讓一系列的 insert 的運行速度提高數倍。(在靜態 SQL 程序中使用主機變量也可以獲得類似的好處。)

2. 發送列值到服務器


可以歸為這一類的優化技巧有好幾種。最重要的一種技巧是在每條 insert 語句中包括多行,這樣就可以避免對于每一行都進行客戶機-服務器通信,同時也減少了 DB2 開銷??捎糜诙嘈胁迦氲募记捎校?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97成人精品视频在线观看| 亚洲一区二区久久久久久久| 91久久精品在线| 久久精品91久久久久久再现| 欧美成人剧情片在线观看| 久久香蕉精品香蕉| 亚洲国产成人精品电影| 81精品国产乱码久久久久久| 久久天天躁夜夜躁狠狠躁2022| 精品福利免费观看| 久久久精品视频在线观看| 日韩av中文字幕在线免费观看| 亚洲图片在线综合| 中文字幕亚洲精品| 亚洲视频在线观看免费| 亚洲最大成人在线| 国产精品青青在线观看爽香蕉| 91精品久久久久久久久| 亚洲免费小视频| 国产精品99久久久久久久久| 亚洲精品电影网| 久热精品视频在线观看一区| 日韩女优人人人人射在线视频| 国产亚洲视频中文字幕视频| 中文字幕日韩欧美在线视频| 国产精品久久久久久久久久久新郎| 亚洲欧美国产精品va在线观看| 国产精品视频午夜| 日韩av黄色在线观看| 久久精品99久久香蕉国产色戒| 欧美日韩爱爱视频| 成人久久精品视频| 狠狠色狠狠色综合日日小说| 亚洲精品在线不卡| 久久最新资源网| 日韩综合中文字幕| 伊人久久免费视频| 久久精品一偷一偷国产| 操人视频在线观看欧美| 亚洲精品99久久久久中文字幕| 91精品久久久久久久久不口人| 久久免费观看视频| 久久久女人电视剧免费播放下载| 日韩av在线免费播放| 亚洲性视频网站| 激情久久av一区av二区av三区| 中文字幕国产亚洲2019| 日韩三级影视基地| 国产精品视频久| 国产福利成人在线| 精品久久久久久久久久ntr影视| 亚洲国产精品小视频| 伊人久久大香线蕉av一区二区| 亚洲成人av片在线观看| 国产精品日韩电影| 欧美猛男性生活免费| 亚洲码在线观看| 92国产精品视频| 欧美黑人巨大精品一区二区| 欧美激情videoshd| 91精品久久久久久久久久久| 精品亚洲aⅴ在线观看| 久久精品这里热有精品| 91免费的视频在线播放| 欧美大尺度电影在线观看| 精品国产电影一区| 久久国产精品久久久久久久久久| 色哟哟亚洲精品一区二区| 国产精品福利无圣光在线一区| 欧美大片网站在线观看| 日韩电影免费在线观看| 中文字幕亚洲色图| 亚洲97在线观看| 亚洲一品av免费观看| 亚洲国产日韩欧美在线动漫| 69av成年福利视频| 4388成人网| 日韩久久免费电影| 国产成一区二区| 亚洲美女在线视频| 91国内免费在线视频| 亚洲第一视频网站| 亚洲在线第一页| 亚洲一区二区三区视频播放| 成人444kkkk在线观看| 久久久伊人日本| 国产精品久久久久久久久久小说| 欧美一区二区三区精品电影| 欧美日韩视频免费播放| 亚洲性av网站| 国产精品日韩在线一区| 中文字幕在线看视频国产欧美在线看完整| 欧美电影免费观看高清| 日韩久久免费电影| 91精品国产综合久久香蕉最新版| 色婷婷亚洲mv天堂mv在影片| 国产精品久久久久福利| 国语自产精品视频在线看| 亚洲性视频网址| 国产欧美婷婷中文| 国产成人精品久久久| 国产免费一区二区三区在线能观看| 一区二区三区四区视频| 欧美放荡办公室videos4k| 懂色av中文一区二区三区天美| 日韩专区在线观看| 成人欧美一区二区三区在线湿哒哒| 91精品免费久久久久久久久| 日韩成人激情在线| 奇米一区二区三区四区久久| 日韩精品免费看| 成人黄色大片在线免费观看| 日韩麻豆第一页| 成人一区二区电影| 日韩欧美视频一区二区三区| 中文字幕日韩在线观看| 狠狠躁夜夜躁人人爽超碰91| 亚洲激情久久久| 中文字幕日韩av电影| 日韩精品视频在线免费观看| 在线视频欧美日韩| 午夜精品久久久久久99热软件| 最近2019中文字幕在线高清| 欧美日韩在线视频观看| 日韩综合视频在线观看| 久久久噜噜噜久噜久久| 久久天堂av综合合色| 亚洲第一免费网站| 国内精品免费午夜毛片| 国产精品久久久久福利| 97成人超碰免| 久久久久久久成人| 日韩电影免费在线观看中文字幕| 欧美成在线观看| 欧美精品www在线观看| 国产精品av免费在线观看| 2019日本中文字幕| 欧美日韩一区二区三区在线免费观看| 中文字幕欧美亚洲| 91精品国产自产在线观看永久| 亚洲mm色国产网站| 久久天天躁狠狠躁夜夜躁| 亚洲第一页在线| 亚洲欧洲一区二区三区在线观看| 日韩在线视频观看正片免费网站| 日韩网站免费观看高清| 91成人在线播放| 欧美国产高跟鞋裸体秀xxxhd| 91精品国产高清久久久久久91| 中文字幕日韩欧美精品在线观看| 91精品国产乱码久久久久久蜜臀| 91久久久亚洲精品| 亚州av一区二区| 日本久久久久久| 91精品视频免费| 日韩中文第一页| 正在播放欧美一区| 91国自产精品中文字幕亚洲| 欧美成人精品h版在线观看| 亚洲乱码国产乱码精品精天堂| 91探花福利精品国产自产在线| 亚洲图片制服诱惑| 精品久久久久久中文字幕大豆网| 91深夜福利视频|