SQL UDFを作成または置換します。
ANSI準拠
CREATE FUNCTION (SQL形式):
この文は、ANSI SQL:2011規格に対するTeradata拡張機能です。
REPLACE FUNCTION (SQL形式):
この文は、ANSI SQL:2011規格に対するTeradata拡張機能です。
必要な権限
CREATE FUNCTIONとREPLACE FUNCTION(SQL形式)の実行に必要な権限は次のように異なります。
- CREATE FUNCTIONリクエストを実行するには、関数を保存するデータベース(UDTに関連したSQL UDFの場合はSYSUDTLIBを含む)に対して明示的なCREATE FUNCTION権限が必要です。
データベースまたはユーザーの作成時に、システムが自動的にCREATE FUNCTION権限を付与することはありません。権限は明示的に付与する必要があります。
データベースまたはユーザーに対して明示的なWITH GRANT OPTION権限を定義しない限り、そのデータベースまたはユーザーが所有するデータベースおよび関数に対してCREATE FUNCTIONが暗黙的に付与されることはありません。
- 既存の関数に対してREPLACE FUNCTION (SQL形式)文を実行するには、関数または関数が含まれるデータベースに対して明示的なDROP FUNCTION権限が必要です。関数を置換する場合、CREATE FUNCTION権限は必要ありません。
- REPLACE FUNCTION (SQL形式)文を実行して新しい関数を作成するには、関数を保存するデータベースに対して明示的なCREATE FUNCTION権限が必要です。
UDTが入力パラメータとして、またはSQL関数の結果として指定される場合、現行ユーザーには次の権限のいずれかが必要です。
- SYSUDTLIBデータベースに対するUDTUSAGE権限。
- 指定されたUDTに対するUDTUSAGE権限。
自動的に与えられる権限
次の権限が、SQL関数の作成者に自動的に与えられます。
- DROP FUNCTION
- EXECUTE FUNCTION