跳到主要内容

CREATE TABLE FUNCTION

引入或更新于:v1.2.799

创建表格式 SQL UDF(UDTF),将 SQL 查询封装为表函数。为保持一致性,使用与标量函数相同的统一 $$ 语法。当前仅支持基于 SQL 的表函数。

语法

CREATE [ OR REPLACE ] FUNCTION [ IF NOT EXISTS ] <function_name> 
( [<parameter_list>] )
RETURNS TABLE ( <column_definition_list> )
AS $$ <sql_statement> $$

其中:

  • <parameter_list>:可选的逗号分隔输入参数及其类型列表(例如 x INT, name VARCHAR
  • <column_definition_list>:函数返回的列名及其类型的逗号分隔列表
  • <sql_statement>:定义函数逻辑的 SQL 查询

统一函数语法

Databend 对标量函数和表函数使用统一的 $$ 语法:

函数类型返回用法
标量函数单个值RETURNS <type> + AS $$ <expression> $$
表函数结果集RETURNS TABLE(...) + AS $$ <query> $$

这种一致性便于理解并在不同函数类型间切换。

示例

基础表函数

-- 创建示例表
CREATE OR REPLACE TABLE employees (
id INT,
name VARCHAR(100),
department VARCHAR(100),
salary DECIMAL(10,2)
);

INSERT INTO employees VALUES
(1, 'John', 'Engineering', 75000),
(2, 'Jane', 'Marketing', 65000),
(3, 'Bob', 'Engineering', 80000),
(4, 'Alice', 'Marketing', 70000);

-- 创建简单表函数获取所有员工
CREATE OR REPLACE FUNCTION get_all_employees()
RETURNS TABLE (id INT, name VARCHAR(100), department VARCHAR(100), salary DECIMAL(10,2))
AS $$ SELECT id, name, department, salary FROM employees $$;

-- 测试函数
SELECT * FROM get_all_employees();

参数化表函数

-- 创建按部门筛选员工的表函数
CREATE OR REPLACE FUNCTION get_employees_by_dept(dept_name VARCHAR)
RETURNS TABLE (id INT, name VARCHAR(100), department VARCHAR(100), salary DECIMAL(10,2))
AS $$ SELECT id, name, department, salary FROM employees WHERE department = dept_name $$;

-- 使用参数化表函数
SELECT * FROM get_employees_by_dept('Engineering');

复杂表函数

-- 创建聚合数据的表函数
CREATE OR REPLACE FUNCTION get_department_stats()
RETURNS TABLE (department VARCHAR(100), employee_count INT, avg_salary DECIMAL(10,2))
AS $$ SELECT department, COUNT(*) as employee_count, AVG(salary) as avg_salary FROM employees GROUP BY department $$;

-- 使用复杂表函数
SELECT * FROM get_department_stats();
开始使用 Databend Cloud
低成本
快速分析
多种数据源
弹性扩展
注册