日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

pgsql的存储过程调用mysql_PostgreSQL存储过程循环调用方式

發(fā)布時(shí)間:2025/3/19 数据库 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 pgsql的存储过程调用mysql_PostgreSQL存储过程循环调用方式 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

需求描述

碰到需求,需要往表里插入5萬(wàn)條數(shù)據(jù), 打算使用存儲(chǔ)過(guò)程,但是postgres 數(shù)據(jù)庫(kù)沒(méi)有建存儲(chǔ)過(guò)程的SQL, 所以使用函數(shù)來(lái)實(shí)現(xiàn).

表數(shù)據(jù)結(jié)構(gòu)完整性要求一次插入兩條記錄, 兩條記錄相互外鍵約束, record1 的 partner_id 字段值是 record2 的主鍵id的值, record2 的 partner_id 字段值是 record1 的主鍵id的值.

實(shí)現(xiàn)

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;

問(wèn)題

這樣子插入只能插入一次, 因?yàn)槿〉眯蛄兄档牡胤皆趂or循環(huán)的外面, id的值不會(huì)隨著循環(huán)再賦值, 主鍵沖突.

辦法

想到可以再對(duì)函數(shù)進(jìn)行循環(huán), 于是再寫一個(gè)函數(shù)循環(huán)執(zhí)行上一個(gè)函數(shù), 去掉上個(gè)函數(shù)中的for 循環(huán)語(yǔ)句FOR i IN 1..500000 LOOP 和 end LOOP;

再寫一個(gè)下面函數(shù)循環(huán)執(zhí)行函數(shù)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;

執(zhí)行函數(shù)

select * from loopCreate() as tab;

好了,完成,10萬(wàn)條數(shù)數(shù)據(jù)秒插, 2.1秒.

PS:CSDN的markdown編輯器真的很難用, 文字稍微長(zhǎng)一點(diǎn)就卡, 而且換行經(jīng)常自動(dòng)調(diào)跳回上一行, 無(wú)奈, 現(xiàn)在都是直接在別的地方寫好粘貼回來(lái)…

補(bǔ)充:postgresql 存儲(chǔ)過(guò)程中遍歷的一個(gè)小問(wèn)題

問(wèn)題

想實(shí)現(xiàn)這種功能,就是 for r in 后面的sql語(yǔ)句是一個(gè)變量,要把以下代碼修改一下

"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;

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

掃描關(guān)注:"WEB開發(fā)者網(wǎng)“公眾號(hào),分享WEB開發(fā)知識(shí),讓開發(fā)變得更簡(jiǎn)單!

總結(jié)

以上是生活随笔為你收集整理的pgsql的存储过程调用mysql_PostgreSQL存储过程循环调用方式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。