PostgreSQL存儲過程循環(huán)調用方式
需求描述
碰到需求,需要往表里插入5萬條數(shù)據(jù), 打算使用存儲過程,但是postgres 數(shù)據(jù)庫沒有建存儲過程的SQL, 所以使用函數(shù)來實現(xiàn).
表數(shù)據(jù)結構完整性要求一次插入兩條記錄, 兩條記錄相互外鍵約束, record1 的 partner_id 字段值是 record2 的主鍵id的值, record2 的 partner_id 字段值是 record1 的主鍵id的值.
實現(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;
問題
這樣子插入只能插入一次, 因為取得序列值的地方在for循環(huán)的外面, id的值不會隨著循環(huán)再賦值, 主鍵沖突.
辦法
想到可以再對函數(shù)進行循環(huán), 于是再寫一個函數(shù)循環(huán)執(zhí)行上一個函數(shù), 去掉上個函數(shù)中的for 循環(huán)語句FOR i IN 1..500000 LOOP 和 end LOOP;
再寫一個下面函數(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萬條數(shù)數(shù)據(jù)秒插, 2.1秒.
PS:CSDN的markdown編輯器真的很難用, 文字稍微長一點就卡, 而且換行經(jīng)常自動調跳回上一行, 無奈, 現(xiàn)在都是直接在別的地方寫好粘貼回來…
補充:postgresql 存儲過程中遍歷的一個小問題
問題
想實現(xiàn)這種功能,就是 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;
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關文章
SQL Server數(shù)據(jù)遷移至PostgreSQL出錯的解釋以及解決方案
最近對SQL Server到PostgreSQL的數(shù)據(jù)遷移時出現(xiàn)了問題,返回的錯誤為:invalid byte sequence for encoding "UTF8": 0x00。經(jīng)查證pg源代碼,該問題引起的原因是sql server的字符類型字段中含有空字符\0,該字符在pg中不支持。2014-09-09淺析postgresql 數(shù)據(jù)庫 TimescaleDB 修改分區(qū)時間范圍
這篇文章主要介紹了淺析postgresql 數(shù)據(jù)庫 TimescaleDB 修改分區(qū)時間范圍,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01PostgreSQL的upsert實例操作(insert on conflict do)
這篇文章主要介紹了PostgreSQL的upsert實例操作(insert on conflict do),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01CentOS PostgreSQL 12 主從復制(主從切換)操作
這篇文章主要介紹了CentOS PostgreSQL 12 主從復制(主從切換)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01PostgreSql 導入導出sql文件格式的表數(shù)據(jù)實例
這篇文章主要介紹了PostgreSql 導入導出sql文件格式的表數(shù)據(jù)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01PostgreSQL教程(一):數(shù)據(jù)表詳解
這篇文章主要介紹了PostgreSQL教程(一):數(shù)據(jù)表詳解表的定義、系統(tǒng)字段、表的修改、表的權限等4大部份內容,內容種包括表的創(chuàng)建、刪除、修改、字段的修改、刪除、主鍵和外鍵、約束添加修改刪除等,本文講解了,需要的朋友可以參考下2015-05-05關于PostgreSql數(shù)據(jù)庫與mysql數(shù)據(jù)庫的不同點以及注意事項
PostgreSQL和MySQL是兩種流行的關系型數(shù)據(jù)庫管理系統(tǒng)(RDBMS),它們都可以用來存儲和管理數(shù)據(jù),但是它們在某些方面有所不同,下面這篇文章主要給大家介紹了關于PostgreSql數(shù)據(jù)庫與mysql數(shù)據(jù)庫的不同點以及注意事項的相關資料,需要的朋友可以參考下2023-05-05