文档中心MogDBMogDB StackUqbar
v5.0

文档:v5.0

支持的版本:

其他版本:

ALTER FUNCTION

功能描述

修改自定义函数的属性。

注意事项

相比于原始的MogDB,dolphin对于ALTER PROCEDURE语法的修改为:

  1. 增加可修改 LANGUAGE 选项。
  2. 增加可修改项 { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA } 。
  3. 增加可修改项 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
    MogDB=# ALTER FUNCTION f1 (s char(20)) NO SQL;

    --指定 CONTAINS SQL
    MogDB=# ALTER FUNCTION f1 (s char(20)) CONTAINS SQL;

    --指定 LANGUAGE SQL
    MogDB=# ALTER FUNCTION f1 (s char(20)) LANGUAGE SQL ;

    --指定 MODIFIES SQL DATA
    MogDB=# ALTER FUNCTION f1 (s char(20)) MODIFIES SQL DATA;

    --指定  READS SQL DATA
    MogDB=# ALTER FUNCTION f1 (s char(20)) READS SQL DATA;

    --指定 SECURITY INVOKER
    MogDB=# ALTER FUNCTION f1 (s char(20)) SQL SECURITY INVOKER;

    --指定 SECURITY DEFINER
    MogDB=# ALTER FUNCTION f1 (s char(20)) SQL SECURITY DEFINER;

相关链接

ALTER FUNCTION

Copyright © 2011-2024 www.enmotech.com All rights reserved.