📣
TiDB Cloud Premium is now in public preview. Unlimited growth, instant elasticity, advanced security for enterprise workloads. Try it out →

ALTER FUNCTION



Alters a user-defined function. Supports all function types: Scalar SQL, Tabular SQL, and Embedded functions.

Syntax

For Scalar SQL Functions

ALTER FUNCTION [ IF EXISTS ] <function_name> ( [<parameter_list>] ) RETURNS <return_type> AS $$ <expression> $$ [ DESC='<description>' ]

For Tabular SQL Functions

ALTER FUNCTION [ IF EXISTS ] <function_name> ( [<parameter_list>] ) RETURNS TABLE ( <column_definition_list> ) AS $$ <sql_statement> $$ [ DESC='<description>' ]

For Embedded Functions

ALTER FUNCTION [ IF EXISTS ] <function_name> ( [<parameter_list>] ) RETURNS <return_type> LANGUAGE <language> [IMPORTS = ('<import_path>', ...)] [PACKAGES = ('<package_path>', ...)] HANDLER = '<handler_name>' AS $$ <function_code> $$ [ DESC='<description>' ]

Examples

Altering Scalar SQL Function

-- Create a scalar function CREATE FUNCTION calculate_tax(income DECIMAL) RETURNS DECIMAL AS $$ income * 0.2 $$; -- Modify the function to use progressive tax rate ALTER FUNCTION calculate_tax(income DECIMAL) RETURNS DECIMAL AS $$ CASE WHEN income <= 50000 THEN income * 0.15 ELSE income * 0.25 END $$;

Altering Tabular SQL Function

-- Create a table function CREATE FUNCTION get_employees() RETURNS TABLE (id INT, name VARCHAR(100)) AS $$ SELECT id, name FROM employees $$; -- Modify to include department and salary ALTER FUNCTION get_employees() RETURNS TABLE (id INT, name VARCHAR(100), department VARCHAR(100), salary DECIMAL) AS $$ SELECT id, name, department, salary FROM employees $$;

Altering Embedded Function

-- Create a Python function CREATE FUNCTION simple_calc(x INT) RETURNS INT LANGUAGE python HANDLER = 'calc' AS $$ def calc(x): return x * 2 $$; -- Modify to use a different calculation ALTER FUNCTION simple_calc(x INT) RETURNS INT LANGUAGE python HANDLER = 'calc' AS $$ def calc(x): return x * 3 + 1 $$;

Was this page helpful?