我有一个plpgsql块,它生成一个动态更新查询:
CREATE OR REPLACE FUNCTION fun_lenght_test () RETURNS VOID AS $BODY$
BEGIN
/*
some code here
*/
dyn_sql = 'UPDATE';
IF SUBSTR(que_col_name, 0, 8) = 'pro_ans' THEN
dyn_sql = dyn_sql || ' profile_answers ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'reg_ans' THEN
dyn_sql = dyn_sql || ' reg_answers ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'tvl_ans' THEN
dyn_sql = dyn_sql || ' tvl_answers ';
END IF;
dyn_sql = dyn_sql|| 'SET' || ' ' || que_col_name || ' = ' || NEW_VALUE_FOR_COLUMN ;
dyn_sql = dyn_sql || ' WHERE' ;
IF SUBSTR(que_col_name, 0, 8) = 'pro_ans' THEN
dyn_sql = dyn_sql || ' pro_ans_frn_pro_id = (SELECT pro_ans_frn_pro_id FROM profile_answers JOIN registrations ON (pro_ans_frn_pro_id = reg_frn_pro_id) WHERE reg_id ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'reg_ans' THEN
dyn_sql = dyn_sql || ' reg_answers WHERE reg_ans_frn_reg_id ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'tvl_ans' THEN
dyn_sql = dyn_sql || ' tvl_answers WHERE tvl_ans_frn_reg_id ';
END IF;
IF SUBSTR(que_col_name, 0, 8) = 'pro_ans' THEN
dyn_sql = dyn_sql || '= ' || CAST(temp_reg AS VARCHAR) || ');';
ELSE
dyn_sql = dyn_sql || '= ' || CAST(temp_reg AS VARCHAR) || ';';
/* want to execute this update dynamic query */
/*
some code here
*/
END;
$BODY$
LANGUAGE plpgsql
是否可以帮我执行此动态更新查询。 在此先感谢。
答案 0 :(得分:1)
创建或替换功能fun_lenght_test() 退回作为 $ BODY $
DECLARE
dyn_sql varchar;
BEGIN
/*
some code here
*/
dyn_sql = 'UPDATE';
IF SUBSTR(que_col_name, 0, 8) = 'pro_ans' THEN
dyn_sql = dyn_sql || ' profile_answers ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'reg_ans' THEN
dyn_sql = dyn_sql || ' reg_answers ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'tvl_ans' THEN
dyn_sql = dyn_sql || ' tvl_answers ';
END IF;
dyn_sql = dyn_sql|| 'SET' || ' ' || que_col_name || ' = ' || NEW_VALUE_FOR_COLUMN ;
dyn_sql = dyn_sql || ' WHERE' ;
IF SUBSTR(que_col_name, 0, 8) = 'pro_ans' THEN
dyn_sql = dyn_sql || ' pro_ans_frn_pro_id = (SELECT pro_ans_frn_pro_id FROM profile_answers JOIN registrations ON (pro_ans_frn_pro_id = reg_frn_pro_id) WHERE reg_id ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'reg_ans' THEN
dyn_sql = dyn_sql || ' reg_answers WHERE reg_ans_frn_reg_id ';
ELSIF SUBSTR(que_col_name, 0, 8) = 'tvl_ans' THEN
dyn_sql = dyn_sql || ' tvl_answers WHERE tvl_ans_frn_reg_id ';
END IF;
IF SUBSTR(que_col_name, 0, 8) = 'pro_ans' THEN
dyn_sql = dyn_sql || '= ' || CAST(temp_reg AS VARCHAR) || ');';
ELSE
dyn_sql = dyn_sql || '= ' || CAST(temp_reg AS VARCHAR) || ';';
END IF;
END; $ BODY $ LANGUAGE plpgsql
我很遗憾知道你想要什么,但这可以运行......