91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在PostgreSQL中循環調用存儲過程

發布時間:2021-01-28 11:43:23 來源:億速云 閱讀:351 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關如何在PostgreSQL中循環調用存儲過程,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

實現

create
 or replace function creatData() returns boolean as $BODY$
declare ii integer;
declare id1 integer;
declare id2 integer;
begin
 ii = 1;
 id1 = nextval('seq_table');
 id2 = nextval('seq_table');
FOR ii IN 1..50000 LOOP
insert
 into
 table1
 values(
 id1,
 10,
 10250,
 5001,
 '2017-08-07 14:00:00',
 '2017-08-07 15:00:00',
 id2,
 true,
 864,
 16950,
 0,
 0,
 0,
 null,
 20,
 null,
 18050,
 '2017-08-07 13:55:08',
 18051,
 '2017-08-07 13:57:28',
 false,
 401,
 10,
 null,
 null,
 null,
 'DA-HZ001000003',
 '2017-08-07 13:54:08',
 '2017-08-07 13:57:28',
 10251
 );
insert
 into
 table1
 values(
 id2,
 10,
 10251,
 5001,
 '2017-08-07 14:00:00',
 '2017-08-07 15:00:00',
 id1,
 true,
 864,
 16950,
 0,
 0,
 0,
 null,
 20,
 null,
 18050,
 '2017-08-07 13:55:08',
 18051,
 '2017-08-07 13:57:28',
 false,
 401,
 10,
 null,
 null,
 null,
 'DA-HZ001000003',
 '2017-08-07 13:54:08',
 '2017-08-07 13:57:28',
 10250
);
end LOOP;
return true;
end;
$BODY$ LANGUAGE plpgsql;

問題

這樣子插入只能插入一次, 因為取得序列值的地方在for循環的外面, id的值不會隨著循環再賦值, 主鍵沖突.

辦法

想到可以再對函數進行循環, 于是再寫一個函數循環執行上一個函數, 去掉上個函數中的for 循環語句FOR i IN 1..500000 LOOP 和 end LOOP;

再寫一個下面函數循環執行函數1

create or replace function loopCreate() 
returns void as 
$BODY$
 begin for i in 1..50000 LOOP 
 PERFORM creatData();
 end LOOP;
end;
$BODY$
LANGUAGE 'plpgsql' VOLATILE;

執行函數

select * from loopCreate() as tab;

好了,完成,10萬條數數據秒插, 2.1秒.

PS:CSDN的markdown編輯器真的很難用, 文字稍微長一點就卡, 而且換行經常自動調跳回上一行, 無奈, 現在都是直接在別的地方寫好粘貼回來…

補充:postgresql 存儲過程中遍歷的一個小問題

問題

想實現這種功能,就是 for r in 后面的sql語句是一個變量,要把以下代碼修改一下

"sqltext" = 'select "ID","ZONENAME" from "ZONE_INFO" where "ID"<>0';
 for r in "sqltext"
loop 
return next r; 
end loop;

解決方法:

sqltext = 'select "ID","ZONENAME" from "ZONE_INFO" where "ID" <>0';
for r in execute sqltext
loop
 return next r;
end loop;

看完上述內容,你們對如何在PostgreSQL中循環調用存儲過程有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南川市| 杭州市| 鄂托克前旗| 哈尔滨市| 黎平县| 安化县| 祥云县| 金阳县| 长沙市| 讷河市| 乐至县| 鄂托克旗| 鄂伦春自治旗| 喀喇沁旗| 察雅县| 夏津县| 福海县| 新乡县| 嘉峪关市| 丹东市| 慈利县| 泸溪县| 宣汉县| 冕宁县| 江北区| 乐亭县| 孟村| 大厂| 蓬溪县| 吉首市| 古田县| 大同市| 乌拉特后旗| 登封市| 阿克苏市| 泌阳县| 延吉市| 青河县| 罗田县| 新闻| 阜南县|