本文介绍了PostgreSQL函数中的保存点的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想在PostgreSQL的函数内使用保存点功能。我读到在postgres的函数中不能使用保存点。
但在回滚时,我希望回滚到特定点,因为我想使用保存点。另一种方法是什么?
示例代码
CREATE or replace FUNCTION fn_loadData_Subha()
RETURNS BIGINT
AS
$$
DECLARE
batchId BIGINT;
currentTime TIMESTAMP;
processName VARCHAR(20);
BEGIN
-- Getting current date and time
select TIMESTAMP 'NOW' into currentTime;
select 'ETL_Subha' INTO processName;
SAVEPOINT first_savepoint;
-- Inserting new record into batch log table
INSERT INTO TB_HSS_BATCH_LOG
(PROCESS_NAME,START_DATE,STATUS)
SELECT processName,currentTime,'STARTED';
select currval('TB_HSS_BATCH_LOG_id_seq') INTO batchId;
-- Inserting cost data to history table
Insert into tb_hss_procedure_cost_hist1
(HOSP_SYSTEM, HOSP_FACILITY, surgeon_name, procedure_name, department, current_dept_rank, no_of_surgeons, current_imp_cost
, current_med_surg_cost, current_total_cost, annual_volume, sys_pref_cost,load_seq_no, CREATED_AT)
Select
HOSP_SYSTEM, HOSP_FACILITY,surgeon_name,procedure_name,department,current_dept_rank, no_of_surgeons, current_imp_cost
, current_med_surg_cost, current_total_cost, annual_volume, sys_pref_cost, batchId,currentTime
from tb_hss_procedure_cost_stag_in;
RELEASE SAVEPOINT first_savepoint;
RETURN 1;
EXCEPTION
WHEN PLPGSQL_ERROR THEN
RAISE EXCEPTION '% %', SQLERRM, SQLSTATE;
RAISE NOTICE '% %', SQLERRM, SQLSTATE;
RETURN 0;
WHEN OTHERS THEN
RAISE EXCEPTION '% %', SQLERRM, SQLSTATE;
RAISE NOTICE '% %', SQLERRM, SQLSTATE;
RETURN 0;
ROLLBACK TRANSACTION;
END;
$$LANGUAGE plpgsql;
推荐答案
在PL/pgSQL函数中使用保存点的方法是使用BEGIN ... EXCEPTION ... END
块。在幕后,这将在BEGIN
设置一个保存点,并在遇到异常时回滚到该保存点。
因此您的代码可能是这样的(我不能100%确定我是否正确地阅读了您的代码):
DECLARE
batchid bigint;
processname varchar(20) := 'ETL_Subha';
BEGIN
BEGIN
INSERT INTO TB_HSS_BATCH_LOG
(PROCESS_NAME,START_DATE,STATUS)
VALUES (processname,current_timestamp,'STARTED')
RETURNING id INTO batchid;
RETURN 1;
EXCEPTION
WHEN OTHERS THEN
RETURN 0;
END;
END;
代码的一些一般性说明:
batchid
从未使用过。currenttime
是不必要的–每次调用current_time
都将在事务中返回相同的值。- 使用
RAISE
引发异常将终止执行。如果希望抛出错误,只需不要捕捉原始异常;它将比您的异常更有意义。我上面的代码假定您希望捕获异常并希望返回0。 SELECT val INTO variable
在幕后与variable := value
相同,但后者通常被认为更具可读性。
这篇关于PostgreSQL函数中的保存点的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!