Postgresql 存儲(chǔ)過(guò)程(plpgsql)兩層for循環(huán)的操作
項(xiàng)目中遇到測(cè)試,需要造4500數(shù)據(jù),而且需要分部門(mén)和日期,一個(gè)部門(mén)一天30條數(shù)據(jù),剩下的鋪墊數(shù)據(jù)可以一個(gè)部門(mén)一天100w左右數(shù)據(jù),這里,每次變換部門(mén),日期,需要操作至少300次,想到用存儲(chǔ)過(guò)程寫(xiě)一個(gè)函數(shù)進(jìn)行
首先,了解存儲(chǔ)過(guò)程的語(yǔ)法:
CREATE [ OR REPLACE ] FUNCTION
name( [ [argmode] [argname]argtype[ { DEFAULT | = }default_expr] [, ...] ] )
[ RETURNSrettype
| RETURNS TABLE (column_namecolumn_type[, ...] ) ]
{ LANGUAGElang_name
| WINDOW
| IMMUTABLE | STABLE | VOLATILE
| CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT
| [ EXTERNAL ] SECURITY INVOKER | [ EXTERNAL ] SECURITY DEFINER
| COSTexecution_cost
| ROWSresult_rows
| SETconfiguration_parameter{ TOvalue| =value| FROM CURRENT }
| AS 'definition'
| AS 'obj_file', 'link_symbol'
} ...
[ WITH (attribute[, ...] ) ]
————————————————
CREATE [ OR REPLACE ] FUNCTION--創(chuàng)建一個(gè)函數(shù),若有此函數(shù),即取代重新創(chuàng)建 name -------函數(shù)名稱(chēng)
RETURNS---函數(shù)返回類(lèi)型
具體的函數(shù)聲明,請(qǐng)參考[postgresql存儲(chǔ)過(guò)程]
下面說(shuō)我寫(xiě)的函數(shù):
CREATE OR REPLACE FUNCTION "xue"."insert_into_table"()
RETURNS "pg_catalog"."void" AS $BODY$
DECLARE tmp VARCHAR(1024);
DECLARE n integer;
DECLARE i integer;
DECLARE inst_seq_no CURSOR FOR
SELECT inst_seq_no FROM t where no in (
'111','22','223','33','4358',
'233','449','315','35335');
BEGIN
RAISE NOTICE '------------start----------';
i := 30;
FOR stmt IN no LOOP
n := 30;
FOR n IN n..i LOOP
insert into test2 (NO,
test_NO,TIME,USER_NO,SEQ_NO,
NAME,USER_NO1,USER_NAME,CODE,USER_NO2,OPROR_NAME,
REVIEW_TIME,DESC,
VAL1,VAL2,DATE,UPD_TIME,DEL_FLAG) values
(nextval('seq_test2'),n,'20190910',n,stmt.seq_no,n,n,n,n,n,n,'20190910','01','',n,n,'20190910',
'20190909','0');
END LOOP;
n = n+30;
i = i+30;
END LOOP;
RAISE NOTICE '-----------finished---------';
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100`
很簡(jiǎn)單的邏輯,但是在修改了三四遍才實(shí)現(xiàn),這個(gè)第二次寫(xiě)存儲(chǔ)過(guò)程,很多語(yǔ)法不是很熟悉,要注意的如:
1.`變量聲明要用DECLARE
2.``游標(biāo) CURSOR 的用法
3.for循環(huán)要在begin中執(zhí)行,
4.循環(huán)中要用“:=”
補(bǔ)充:Postgresql中存儲(chǔ)過(guò)程(函數(shù))調(diào)用存儲(chǔ)過(guò)程(函數(shù))時(shí)應(yīng)用注意的問(wèn)題
在postgresql中我們?cè)趫?zhí)行存儲(chǔ)過(guò)程中往往會(huì)使用select 存儲(chǔ)過(guò)程,但是如果存儲(chǔ)過(guò)程中再調(diào)用 存儲(chǔ)過(guò)程時(shí),就不能這樣用了,應(yīng)該用perform 存儲(chǔ)過(guò)程,可以去參考官方文檔的說(shuō)明
執(zhí)行一個(gè)沒(méi)有結(jié)果的表達(dá)式或者命令
有時(shí)候我們希望計(jì)算一個(gè)表達(dá)式或者一個(gè)命令,但是卻丟棄其結(jié)果(通常因?yàn)槲覀兘?jīng)常調(diào)用一些存在有用的副作用但是不存在有用結(jié)果值的函數(shù))。 要在 PL/pgSQL 里干這件事, 你可以使用PERFORM語(yǔ)句:
PERFORM query;
這條語(yǔ)句執(zhí)行一個(gè) query并且丟棄結(jié)果。 query 的寫(xiě)法和你平常寫(xiě) SQL SELECT 命令是一樣的, 只是把開(kāi)頭的關(guān)鍵字 SELECT 替換成 PERFORM。 PL/pgSQL 的變量和平常一樣代換到命令中。 同樣,如果命令生成至少一行,那么特殊的變量 FOUND 設(shè)置為真,如果沒(méi)有生成行,則為假。
注意: 我們可能希望沒(méi)有INTO子句的SELECT也能滿(mǎn)足這樣的需要, 但是目前可以接受的唯一的方法是PERFORM。
一個(gè)例子:
PERFORM create_mv('cs_session_page_requests_mv', my_query);
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
- PostgreSQL存儲(chǔ)過(guò)程循環(huán)調(diào)用方式
- PostgreSQL存儲(chǔ)過(guò)程用法實(shí)戰(zhàn)詳解
- Mybatis調(diào)用PostgreSQL存儲(chǔ)過(guò)程實(shí)現(xiàn)數(shù)組入?yún)鬟f
- PostgreSQL中調(diào)用存儲(chǔ)過(guò)程并返回?cái)?shù)據(jù)集實(shí)例
- 初識(shí)PostgreSQL存儲(chǔ)過(guò)程
- PostgreSQL 存儲(chǔ)過(guò)程的進(jìn)階講解(含游標(biāo)、錯(cuò)誤處理、自定義函數(shù)、事務(wù))
相關(guān)文章
Postgresql數(shù)據(jù)庫(kù)中的json類(lèi)型字段使用示例詳解
JSON的主要用于在服務(wù)器與web應(yīng)用之間傳輸數(shù)據(jù),這篇文章主要介紹了Postgresql數(shù)據(jù)庫(kù)中的json類(lèi)型字段使用,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02
解決sqoop import 導(dǎo)入到hive后數(shù)據(jù)量變多的問(wèn)題
這篇文章主要介紹了解決sqoop import 導(dǎo)入到hive后數(shù)據(jù)量變多的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
基于postgresql數(shù)據(jù)庫(kù)鎖表問(wèn)題的解決
這篇文章主要介紹了基于postgresql數(shù)據(jù)庫(kù)鎖表問(wèn)題的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
PostgreSQL之分區(qū)表(partitioning)
通過(guò)合理的設(shè)計(jì),可以將選擇一定的規(guī)則,將大表切分多個(gè)不重不漏的子表,這就是傳說(shuō)中的partitioning。比如,我們可以按時(shí)間切分,每天一張子表,比如我們可以按照某其他字段分割,總之了就是化整為零,提高查詢(xún)的效能2016-11-11
PostgreSQL pg_ctl start啟動(dòng)超時(shí)實(shí)例分析
這篇文章主要給大家介紹了關(guān)于PostgreSQL pg_ctl start啟動(dòng)超時(shí)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01
Postgresql數(shù)據(jù)庫(kù)角色創(chuàng)建登錄詳解
這篇文章主要為大家介紹了Postgresql數(shù)據(jù)庫(kù)角色創(chuàng)建登錄詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
Postgresql psql文件執(zhí)行與批處理多個(gè)sql文件操作
這篇文章主要介紹了Postgresql psql文件執(zhí)行與批處理多個(gè)sql文件操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01
PostgreSQL upsert(插入更新)數(shù)據(jù)的操作詳解
這篇文章主要介紹了PostgreSQL upsert(插入更新)教程詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01

