校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > postgresql 13.1 insert into select并行查詢的實(shí)現(xiàn)

postgresql 13.1 insert into select并行查詢的實(shí)現(xiàn)

熱門標(biāo)簽:移動(dòng)外呼系統(tǒng)模擬題 電話機(jī)器人怎么換人工座席 400電話申請(qǐng)客服 江蘇400電話辦理官方 廣州電銷機(jī)器人公司招聘 天津開發(fā)區(qū)地圖標(biāo)注app 濟(jì)南外呼網(wǎng)絡(luò)電話線路 地圖標(biāo)注要花多少錢 電銷機(jī)器人能補(bǔ)救房產(chǎn)中介嗎

本文信息基于PG13.1。

從PG9.6開始支持并行查詢。PG11開始支持CREATE TABLE … AS、SELECT INTO以及CREATE MATERIALIZED VIEW的并行查詢。

先說(shuō)結(jié)論:

換用create table as 或者select into或者導(dǎo)入導(dǎo)出。

首先跟蹤如下查詢語(yǔ)句的執(zhí)行計(jì)劃:

select count(*) from test t1,test1 t2 where t1.id = t2.id ;
postgres=# explain analyze select count(*) from test t1,test1 t2 where t1.id = t2.id ;
                  QUERY PLAN                  
-------------------------------------------------------------------------------------------
Finalize Aggregate (cost=34244.16..34244.17 rows=1 width=8) (actual time=683.246..715.324 rows=1 loops=1)
 -> Gather (cost=34243.95..34244.16 rows=2 width=8) (actual time=681.474..715.311 rows=3 loops=1)
   Workers Planned: 2
   Workers Launched: 2
   -> Partial Aggregate (cost=33243.95..33243.96 rows=1 width=8) (actual time=674.689..675.285 rows=1 loops=3)
    -> Parallel Hash Join (cost=15428.00..32202.28 rows=416667 width=0) (actual time=447.799..645.689 rows=333333 loops=3)
      Hash Cond: (t1.id = t2.id)
      -> Parallel Seq Scan on test t1 (cost=0.00..8591.67 rows=416667 width=4) (actual time=0.025..74.010 rows=333333 loops=3)
      -> Parallel Hash (cost=8591.67..8591.67 rows=416667 width=4) (actual time=260.052..260.053 rows=333333 loops=3)
       Buckets: 131072 Batches: 16 Memory Usage: 3520kB
       -> Parallel Seq Scan on test1 t2 (cost=0.00..8591.67 rows=416667 width=4) (actual time=0.032..104.804 rows=333333 loops=3)
 Planning Time: 0.420 ms
 Execution Time: 715.447 ms
(13 rows)

可以看到走了兩個(gè)Workers。

下邊看一下insert into select:

postgres=# explain analyze insert into va select count(*) from test t1,test1 t2 where t1.id = t2.id ;   
                 QUERY PLAN                 
-------------------------------------------------------------------------------------------
Insert on va (cost=73228.00..73228.02 rows=1 width=4) (actual time=3744.179..3744.187 rows=0 loops=1)
 -> Subquery Scan on "*SELECT*" (cost=73228.00..73228.02 rows=1 width=4) (actual time=3743.343..3743.352 rows=1 loops=1)
   -> Aggregate (cost=73228.00..73228.01 rows=1 width=8) (actual time=3743.247..3743.254 rows=1 loops=1)
    -> Hash Join (cost=30832.00..70728.00 rows=1000000 width=0) (actual time=1092.295..3511.301 rows=1000000 loops=1)
      Hash Cond: (t1.id = t2.id)
      -> Seq Scan on test t1 (cost=0.00..14425.00 rows=1000000 width=4) (actual time=0.030..421.537 rows=1000000 loops=1)
      -> Hash (cost=14425.00..14425.00 rows=1000000 width=4) (actual time=1090.078..1090.081 rows=1000000 loops=1)
       Buckets: 131072 Batches: 16 Memory Usage: 3227kB
       -> Seq Scan on test1 t2 (cost=0.00..14425.00 rows=1000000 width=4) (actual time=0.021..422.768 rows=1000000 loops=1)
 Planning Time: 0.511 ms
 Execution Time: 3745.633 ms
(11 rows)

可以看到并沒有Workers的指示,沒有啟用并行查詢。

即使開啟強(qiáng)制并行,也無(wú)法走并行查詢。

postgres=# set force_parallel_mode =on;
SET
postgres=# explain analyze insert into va select count(*) from test t1,test1 t2 where t1.id = t2.id ;
                 QUERY PLAN                 
-------------------------------------------------------------------------------------------
Insert on va (cost=73228.00..73228.02 rows=1 width=4) (actual time=3825.042..3825.049 rows=0 loops=1)
 -> Subquery Scan on "*SELECT*" (cost=73228.00..73228.02 rows=1 width=4) (actual time=3824.976..3824.984 rows=1 loops=1)
   -> Aggregate (cost=73228.00..73228.01 rows=1 width=8) (actual time=3824.972..3824.978 rows=1 loops=1)
    -> Hash Join (cost=30832.00..70728.00 rows=1000000 width=0) (actual time=1073.587..3599.402 rows=1000000 loops=1)
      Hash Cond: (t1.id = t2.id)
      -> Seq Scan on test t1 (cost=0.00..14425.00 rows=1000000 width=4) (actual time=0.034..414.965 rows=1000000 loops=1)
      -> Hash (cost=14425.00..14425.00 rows=1000000 width=4) (actual time=1072.441..1072.443 rows=1000000 loops=1)
       Buckets: 131072 Batches: 16 Memory Usage: 3227kB
       -> Seq Scan on test1 t2 (cost=0.00..14425.00 rows=1000000 width=4) (actual time=0.022..400.624 rows=1000000 loops=1)
 Planning Time: 0.577 ms
 Execution Time: 3825.923 ms
(11 rows)

原因在官方文檔有寫:

The query writes any data or locks any database rows. If a query contains a data-modifying operation either at the top level or within a CTE, no parallel plans for that query will be generated. As an exception, the commands CREATE TABLE … AS, SELECT INTO, and CREATE MATERIALIZED VIEW which create a new table and populate it can use a parallel plan.

解決方案有如下三種:

1.select into

postgres=# explain analyze select count(*) into vaa from test t1,test1 t2 where t1.id = t2.id ;
                  QUERY PLAN                  
-------------------------------------------------------------------------------------------
Finalize Aggregate (cost=34244.16..34244.17 rows=1 width=8) (actual time=742.736..774.923 rows=1 loops=1)
 -> Gather (cost=34243.95..34244.16 rows=2 width=8) (actual time=740.223..774.907 rows=3 loops=1)
   Workers Planned: 2
   Workers Launched: 2
   -> Partial Aggregate (cost=33243.95..33243.96 rows=1 width=8) (actual time=731.408..731.413 rows=1 loops=3)
    -> Parallel Hash Join (cost=15428.00..32202.28 rows=416667 width=0) (actual time=489.880..700.830 rows=333333 loops=3)
      Hash Cond: (t1.id = t2.id)
      -> Parallel Seq Scan on test t1 (cost=0.00..8591.67 rows=416667 width=4) (actual time=0.033..87.479 rows=333333 loops=3)
      -> Parallel Hash (cost=8591.67..8591.67 rows=416667 width=4) (actual time=266.839..266.840 rows=333333 loops=3)
       Buckets: 131072 Batches: 16 Memory Usage: 3520kB
       -> Parallel Seq Scan on test1 t2 (cost=0.00..8591.67 rows=416667 width=4) (actual time=0.058..106.874 rows=333333 loops=3)
 Planning Time: 0.319 ms
 Execution Time: 783.300 ms
(13 rows)

2.create table as

postgres=# explain analyze create table vb as select count(*) from test t1,test1 t2 where t1.id = t2.id ;
                  QUERY PLAN                  
-------------------------------------------------------------------------------------------
 Finalize Aggregate (cost=34244.16..34244.17 rows=1 width=8) (actual time=540.120..563.733 rows=1 loops=1)
 -> Gather (cost=34243.95..34244.16 rows=2 width=8) (actual time=537.982..563.720 rows=3 loops=1)
   Workers Planned: 2
   Workers Launched: 2
   -> Partial Aggregate (cost=33243.95..33243.96 rows=1 width=8) (actual time=526.602..527.136 rows=1 loops=3)
    -> Parallel Hash Join (cost=15428.00..32202.28 rows=416667 width=0) (actual time=334.532..502.793 rows=333333 loops=3)
      Hash Cond: (t1.id = t2.id)
      -> Parallel Seq Scan on test t1 (cost=0.00..8591.67 rows=416667 width=4) (actual time=0.018..57.819 rows=333333 loops=3)
      -> Parallel Hash (cost=8591.67..8591.67 rows=416667 width=4) (actual time=189.502..189.503 rows=333333 loops=3)
       Buckets: 131072 Batches: 16 Memory Usage: 3520kB
       -> Parallel Seq Scan on test1 t2 (cost=0.00..8591.67 rows=416667 width=4) (actual time=0.023..77.786 rows=333333 loops=3)
 Planning Time: 0.189 ms
 Execution Time: 565.448 ms
(13 rows)

3.或者通過(guò)導(dǎo)入導(dǎo)出的方式,例如:

psql -h localhost -d postgres -U postgres -c "select count(*) from test t1,test1 t2 where t1.id = t2.id " -o result.csv -A -t -F ","
psql -h localhost -d postgres -U postgres -c "COPY va FROM 'result.csv' WITH (FORMAT CSV, DELIMITER ',', HEADER FALSE, ENCODING 'windows-1252')"

一些場(chǎng)景下也會(huì)比非并行快。

補(bǔ)充:POSTGRESQL: 動(dòng)態(tài)SQL語(yǔ)句中不能使用SELECT INTO?

我的數(shù)據(jù)庫(kù)版本是 PostgreSQL 8.4.7 。 下面是出錯(cuò)的存儲(chǔ)過(guò)程:

CREATE or Replace FUNCTION func_getnextid(
 tablename varchar(240),
 idname varchar(20) default 'id')
RETURNS integer AS $funcbody$
Declare
 sqlstring varchar(240);
 currentId integer;
Begin
 sqlstring:= 'select max("' || idname || '") into currentId from "' || tablename || '";';
 EXECUTE sqlstring;
 if currentId is NULL or currentId = 0 then
  return 1;
 else
  return currentId + 1;
 end if;
End;
$funcbody$ LANGUAGE plpgsq

執(zhí)行后出現(xiàn)這樣的錯(cuò)誤:

SQL error:

ERROR: EXECUTE of SELECT ... INTO is not implemented

CONTEXT: PL/pgSQL function "func_getnextbigid" line 6 at EXECUTE statement

改成這樣的就對(duì)了:

CREATE or Replace FUNCTION func_getnextid(
 tablename varchar(240),
 idname varchar(20) default 'id')
RETURNS integer AS $funcbody$
Declare
 sqlstring varchar(240);
 currentId integer;
Begin
 sqlstring:= 'select max("' || idname || '") from "' || tablename || '";';
 EXECUTE sqlstring into currentId;
 if currentId is NULL or currentId = 0 then
  return 1;
 else
  return currentId + 1;
 end if;
End;
$funcbody$ LANGUAGE plpgsql;

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • postgresql insert into select無(wú)法使用并行查詢的解決
  • mysql 中 replace into 與 insert into on duplicate key update 的用法和不同點(diǎn)實(shí)例分析
  • SELECT INTO 和 INSERT INTO SELECT 兩種表復(fù)制語(yǔ)句詳解(SQL數(shù)據(jù)庫(kù)和Oracle數(shù)據(jù)庫(kù)的區(qū)別)
  • php mysql insert into 結(jié)合詳解及實(shí)例代碼
  • PHP+MySQL之Insert Into數(shù)據(jù)插入用法分析
  • 正確使用MySQL INSERT INTO語(yǔ)句
  • MySql中使用INSERT INTO語(yǔ)句更新多條數(shù)據(jù)的例子
  • SQL insert into語(yǔ)句寫法講解

標(biāo)簽:濮陽(yáng) 杭州 榆林 辛集 海西 昭通 寶雞 溫州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《postgresql 13.1 insert into select并行查詢的實(shí)現(xiàn)》,本文關(guān)鍵詞  postgresql,13.1,insert,into,select,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《postgresql 13.1 insert into select并行查詢的實(shí)現(xiàn)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于postgresql 13.1 insert into select并行查詢的實(shí)現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    精品伊人久久久久7777人| 国产精品美女久久福利网站| 日韩av中文字幕一区二区 | 欧美精选一区二区| 久久久精品免费免费| 51精品视频一区二区三区| 蜜臀久久久久久久| 一区二区三区日韩欧美精品| 中文字幕中文字幕中文字幕亚洲无线 | 亚洲一区在线看| 99久久精品一区| 亚洲欧美激情视频在线观看一区二区三区 | 欧美性受xxxx黑人xyx性爽| 亚洲精品ww久久久久久p站| 日韩美女啊v在线免费观看| 久久精品亚洲国产奇米99| 亚洲国产精品成人久久综合一区| 欧美日韩精品是欧美日韩精品| 欧美亚洲免费在线一区| 国产又粗又猛又爽又黄91精品| 狠狠色狠狠色综合系列| 亚洲成人自拍一区| 亚洲国产精品一区二区久久| 日韩你懂的在线观看| 欧美α欧美αv大片| 欧美日韩国产大片| 国产69精品一区二区亚洲孕妇| 国产午夜久久久久| 91丨九色丨黑人外教| 午夜国产不卡在线观看视频| 欧美成人午夜电影| 一本一本久久a久久精品综合麻豆| 亚洲电影视频在线| 久久久国际精品| 日韩一区二区在线看| 精品国内二区三区| 欧美成人在线直播| 久久综合99re88久久爱| 日韩女优av电影| 欧美日韩一区二区三区高清| 国产伦精品一区二区三区免费| 国产一区二区三区日韩| 国产盗摄视频一区二区三区| 依依成人精品视频| 日本一区二区视频在线观看| 国产精品二三区| 亚洲国产一区二区视频| 日韩av在线播放中文字幕| 久草这里只有精品视频| 高潮精品一区videoshd| 91蜜桃在线免费视频| 日韩视频永久免费| 国产亚洲一本大道中文在线| 国产精品久久久久一区二区三区 | 成人黄页在线观看| 一本色道a无线码一区v| 在线播放国产精品二区一二区四区| 日韩欧美亚洲国产精品字幕久久久| 久久蜜臀精品av| 一区二区三区精品在线| 久久国产精品区| 一本到三区不卡视频| 日韩欧美一二三| 最新热久久免费视频| 午夜精品福利视频网站| 国产老女人精品毛片久久| 色哟哟一区二区在线观看| 精品国产一区久久| 樱桃国产成人精品视频| 国产一区欧美日韩| 欧美日韩免费一区二区三区视频 | 亚洲精品免费在线观看| 狠狠狠色丁香婷婷综合久久五月| 91视频精品在这里| 精品国产一区二区国模嫣然| 一区二区欧美精品| 成人免费视频网站在线观看| 欧美一级搡bbbb搡bbbb| 一区二区三区小说| 丁香激情综合国产| 欧美一级一区二区| 亚洲最大成人综合| av一区二区三区| 久久夜色精品国产噜噜av| 亚洲成人动漫在线观看| 91视频免费播放| 欧美韩日一区二区三区| 久久99精品久久久久久久久久久久 | 免费成人av在线播放| 一本色道久久综合亚洲aⅴ蜜桃 | 美女性感视频久久| 在线影院国内精品| 国产日产精品1区| 麻豆成人免费电影| 波多野结衣中文一区| 久久嫩草精品久久久精品| 夜夜亚洲天天久久| 国产成人在线视频网站| 精品乱码亚洲一区二区不卡| 午夜伊人狠狠久久| 欧美性猛片aaaaaaa做受| 亚洲青青青在线视频| 9人人澡人人爽人人精品| 国产日韩综合av| 国产精品538一区二区在线| 日韩精品资源二区在线| 天天色综合天天| 欧美久久婷婷综合色| 亚洲午夜免费电影| 在线观看av一区二区| 亚洲人123区| 一本久久综合亚洲鲁鲁五月天 | 欧美成人伊人久久综合网| 午夜亚洲福利老司机| 色综合咪咪久久| 中文字幕亚洲电影| 国产精品自产自拍| 久久久精品国产免大香伊| 国产精品18久久久久久久久| 久久久夜色精品亚洲| 日产精品久久久久久久性色| 色综合久久久久综合体桃花网| 亚洲丝袜另类动漫二区| 国产乱码精品1区2区3区| 欧美精品一区二区在线观看| 蜜乳av一区二区| 日韩欧美一区二区视频| 狠狠网亚洲精品| 国产亚洲一区二区三区在线观看| 国产91精品一区二区麻豆网站| 国产女人aaa级久久久级| 成人aa视频在线观看| 亚洲免费观看高清完整版在线观看| 色综合天天狠狠| 高清视频一区二区| 中文在线一区二区| 一本久久a久久精品亚洲| 一区二区三区资源| 91.com视频| 国产一区二区三区日韩| 国产精品天干天干在线综合| 91亚洲男人天堂| 午夜激情一区二区三区| 欧美成人精品二区三区99精品| 国产麻豆精品一区二区| 中文字幕亚洲欧美在线不卡| 91精品1区2区| 久久国产精品无码网站| 国产精品丝袜一区| 91美女视频网站| 日韩高清不卡在线| 久久蜜桃香蕉精品一区二区三区| 不卡大黄网站免费看| 午夜欧美2019年伦理| 精品国产精品一区二区夜夜嗨| 国产激情偷乱视频一区二区三区 | 亚洲h动漫在线| 久久久久久久久99精品| 日本高清不卡aⅴ免费网站| 日韩在线a电影| 国产精品国产三级国产aⅴ入口| 欧美日韩精品综合在线| 国产精品小仙女| 亚洲一区二区三区四区五区黄| 精品蜜桃在线看| 色综合中文字幕国产| 亚洲一区二区三区自拍| 欧美大片日本大片免费观看| 成人白浆超碰人人人人| 日韩精品一区第一页| 国产精品素人一区二区| 91精品国产综合久久小美女| 成人av一区二区三区| 青草国产精品久久久久久| 亚洲欧美综合色| 日韩欧美国产高清| 99久久精品国产导航| 久久国产精品一区二区| 亚洲综合色丁香婷婷六月图片| 精品国产一区二区三区忘忧草| 91九色02白丝porn| 丰满少妇在线播放bd日韩电影| 午夜av区久久| 亚洲日本成人在线观看| 久久欧美一区二区| 欧美一区二区精品| 欧美性大战久久久久久久| 国产.欧美.日韩| 麻豆精品在线视频| 亚洲韩国精品一区| 亚洲欧美综合色| 国产情人综合久久777777| 4438x成人网最大色成网站| 91猫先生在线| 粉嫩一区二区三区在线看| 久久99精品视频| 日本v片在线高清不卡在线观看| 一区二区三区 在线观看视频| 国产精品伦一区二区三级视频| 日韩免费成人网|