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;