濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > PostgreSQL存儲(chǔ)過(guò)程循環(huán)調(diào)用方式

PostgreSQL存儲(chǔ)過(guò)程循環(huán)調(diào)用方式

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

需求描述

碰到需求,需要往表里插入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è)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 解決postgresql表中的字段名稱包含特殊符號(hào)的問(wèn)題
  • postgresql數(shù)據(jù)庫(kù)使用說(shuō)明_實(shí)現(xiàn)時(shí)間范圍查詢
  • postgresql 實(shí)現(xiàn)將數(shù)組變?yōu)樾?/li>
  • PostgreSQL 對(duì)數(shù)組的遍歷操作
  • postgresql 存儲(chǔ)函數(shù)調(diào)用變量的3種方法小結(jié)
  • postgresql~*符號(hào)的含義及用法說(shuō)明

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL存儲(chǔ)過(guò)程循環(huán)調(diào)用方式》,本文關(guān)鍵詞  PostgreSQL,存儲(chǔ),過(guò)程,循環(huán),;如發(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存儲(chǔ)過(guò)程循環(huán)調(diào)用方式》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于PostgreSQL存儲(chǔ)過(guò)程循環(huán)調(diào)用方式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    安阳县| 庄河市| 静乐县| 朝阳市| 凯里市| 神农架林区| 杂多县| 松阳县| 龙江县| 岑溪市| 东丰县| 河源市| 三亚市| 勐海县| 乌海市| 洪洞县| 饶河县| 浪卡子县| 虞城县| 阜康市| 缙云县| 斗六市| 海伦市| 赤城县| 神木县| 洪江市| 南昌县| 威信县| 子长县| 萍乡市| 沭阳县| 石棉县| 金秀| 微山县| 古蔺县| 永泰县| 从江县| 卢氏县| 镇原县| 绥中县| 项城市|