ALTER FUNCTION
功能描述
修改自定义函数的属性。
注意事项
相比于原始的openGauss,dolphin对于ALTER PROCEDURE语法的修改为:
增加可修改 LANGUAGE 选项。
增加可修改项 { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA } 。
增加可修改项 SQL SECURITY { DEFINER | INVOKER }。
语法格式
修改自定义函数的附加参数。
ALTER FUNCTION function_name ( [ { [ argname ] [ argmode ] argtype} [, ...] ] ) action [ ... ] [ RESTRICT ];
其中附加参数action子句语法为。
{CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT} | {IMMUTABLE | STABLE | VOLATILE} | {SHIPPABLE | NOT SHIPPABLE} | {NOT FENCED | FENCED} | [ NOT ] LEAKPROOF | { [ EXTERNAL|SQL ] SECURITY INVOKER | [ EXTERNAL|SQL ] SECURITY DEFINER } | AUTHID { DEFINER | CURRENT_USER } | COST execution_cost | ROWS result_rows | SET configuration_parameter { { TO | = } { value | DEFAULT }| FROM CURRENT} | RESET {configuration_parameter | ALL} | COMMENT 'text' | LANGUAGE lang_name | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA }
参数说明
LANGUAGE lang_name
用以实现函数的语言的名称,仅语法兼容,实际修改不会生效。
SQL SECURITY INVOKER
表明该函数将带着调用它的用户的权限执行。该参数可以省略。
SQL SECURITY INVOKER和SECURITY INVOKER和AUTHID CURRENT_USER的功能相同。
SQL SECURITY DEFINER
声明该函数将以创建它的用户的权限执行。
SQL SECURITY DEFINER和AUTHID DEFINER和SECURITY DEFINER的功能相同。
CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA
语法兼容项。
示例
--指定 NO SQL
openGauss=# ALTER FUNCTION f1 (s char(20)) NO SQL;
--指定 CONTAINS SQL
openGauss=# ALTER FUNCTION f1 (s char(20)) CONTAINS SQL;
--指定 LANGUAGE SQL
openGauss=# ALTER FUNCTION f1 (s char(20)) LANGUAGE SQL ;
--指定 MODIFIES SQL DATA
openGauss=# ALTER FUNCTION f1 (s char(20)) MODIFIES SQL DATA;
--指定 READS SQL DATA
openGauss=# ALTER FUNCTION f1 (s char(20)) READS SQL DATA;
--指定 SECURITY INVOKER
openGauss=# ALTER FUNCTION f1 (s char(20)) SQL SECURITY INVOKER;
--指定 SECURITY DEFINER
openGauss=# ALTER FUNCTION f1 (s char(20)) SQL SECURITY DEFINER;
相关链接
意见反馈