好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PostgreSQL存儲過程循環調用方式

PostgreSQL存儲過程循環調用方式

熱門標簽:江蘇400電話辦理官方 移動外呼系統模擬題 濟南外呼網絡電話線路 電話機器人怎么換人工座席 400電話申請客服 電銷機器人能補救房產中介嗎 廣州電銷機器人公司招聘 天津開發區地圖標注app 地圖標注要花多少錢

需求描述

碰到需求,需要往表里插入5萬條數據, 打算使用存儲過程,但是postgres 數據庫沒有建存儲過程的SQL, 所以使用函數來實現.

表數據結構完整性要求一次插入兩條記錄, 兩條記錄相互外鍵約束, record1 的 partner_id 字段值是 record2 的主鍵id的值, record2 的 partner_id 字段值是 record1 的主鍵id的值.

實現

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表中的字段名稱包含特殊符號的問題
  • postgresql數據庫使用說明_實現時間范圍查詢
  • postgresql 實現將數組變為行
  • PostgreSQL 對數組的遍歷操作
  • postgresql 存儲函數調用變量的3種方法小結
  • postgresql~*符號的含義及用法說明

標簽:辛集 昭通 濮陽 榆林 海西 寶雞 溫州 杭州

巨人網絡通訊聲明:本文標題《PostgreSQL存儲過程循環調用方式》,本文關鍵詞  PostgreSQL,存儲,過程,循環,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PostgreSQL存儲過程循環調用方式》相關的同類信息!
  • 本頁收集關于PostgreSQL存儲過程循環調用方式的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲欧美高清视频| 久久综合亚洲色hezyo国产| 91在线无码精品秘?入口竹美| aaaaa级毛片免费视频| 樱花草WWW视频在线播放| 无码人妻精品一区二区三区蜜桃91| 欧美黑人添添高潮A片视频| 新视觉6080高清电视剧2024| 中国孕妇疯狂xxxxbbbb| 国产福利91精品一区二区三区| 影音先锋女人aV鲁色资源网七七| 丁香花免费高清完整在线观看| 日韩中文字幕在线| 999国产高清在线精品| 99久久精品人妻无码一区二区三区| 717电影网午夜福利理伦| 性生活毛片| 天天视频免费入口| 亚洲欧美曰韩国产综合图片| 日韩欧精品一区二区| 软糯小受在情侣酒店里做| 国产午夜精品一区理论片飘花| 校花灌浣肠惩罚| 英语老师解开胸罩喂我乳视频| 成人免费淫片免费观看| 视频一区二区村上凉子| 国内精品久久久久影院薰衣草| 91亚洲乱码卡一卡二卡新区豆瓣 | eutopia动漫完整版观看| 小雪在公车被灌满jing液渺渺 | 色琪琪一区二区三区亚洲区| 成熟女人网站免费大片| 欧美性xxx极品| 啊啊啊啊啊用力| 久久精品青草社区| 国产又爽又猛又粗的视频A片| 欧美同性男男gayxxxx网站| 欧美三级一区| 白雪公主婬荡呻吟h文| 桌下含校园污肉高h| でも私はあなたより賢いです意思 |