\1. 赋值:
PL/pgSQL中赋值语句的形式为:identIFier := expression,等号两端的变量和表达式的类型或者一致, 或者可以通过PostgreSQL的转换规则进行转换,否则将会导致运行时错误,见如下示例:
\2. SELECT INTO:
通过该语句可以为记录变量或行类型变量进行赋值,其表现形式为:SELECT INTO target select_expressions FROM ...,该赋值方式一次只能赋值一个变量。表达式中的target可以表示为是一个 记录变量、行变量,或者是一组用逗号分隔的简单变量和记录/行字段的列表。select_expressions以及 剩余部分和普通SQL一样。 如果将一行或者一个变量列表用做目标,那么选出的数值必需精确匹配目标的结构,否则就会产生运行 时错误。如果目标是一个记录变量,那么它自动将自己构造成命令结果列的行类型。如果命令返回零 行,目标被赋予空值。如果命令返回多行,那么将只有第一行被赋予目标,其它行将被忽略。在执行 SELECT INTO语句之后,可以通过检查内置变量FOUND来判断本次赋值是否成功,如:
name RECORD;
user_id := 20;
tax := subtotal * 0.06;
CREATE FUNCTION merge_fields(t_row table1) RETURNS text AS $$
DECLARE t2_row table2%ROWTYPE; BEGIN SELECT * INTO t2_row FROM table2 WHERE id = 1 limit 1; RETURN t_row.f1 || t2_row.f3 || t_row.f5 || t2_row.f7; END; $$ LANGUAGE plpgsql;
要测试一个记录/行结果是否为空,可以使用IS NULL条件进行判断,但是对于返回多条记录的情况则无 法判断,如:
DECLARE
users_rec RECORD; BEGIN SELECT INTO users_rec * FROM users WHERE user_id = 3; IF users_rec.homepage IS NULL THEN RETURN 'http://'; END IF;
END;
\3. 执行一个没有结果的表达式或者命令:
在调用一个表达式或执行一个命令时,如果对其返回的结果不感兴趣,可以考虑使用PERFORM语句: PERFORM query,该语句将执行PERFORM之后的命令并忽略其返回的结果。其中query的写法和普通 的SQL SELECT命令是一样的,只是把开头的关键字SELECT替换成PERFORM,如:
\4. 执行动态命令:
如果在PL/pgSQL函数中操作的表或数据类型在每次调用该函数时都可能会发生变化,在这样的情况下, 可以考虑使用PL/pgSQL提供的EXECUTE语句:EXECUTE command-string [ INTO target ],其中 command-string是用一段文本表示的表达式,它包含要执行的命令。而target是一个记录变量、行变量 或者一组用逗号分隔的简单变量和记录/行域的列表。这里需要特别注意的是,该命令字符串将不会发生 任何PL/pgSQL变量代换,变量的数值必需在构造命令字符串时插入到该字符串中。
和所有其它PL/pgSQL命令不同的是,一个由EXECUTE语句运行的命令在服务器内并不会只prepare和保 存一次。相反,该语句在每次运行的时候,命令都会prepare一次。因此命令字符串可以在函数里动态 的生成以便于对各种不同的表和字段进行操作,从而提高函数的灵活性。然而由此换来的却是性能上的 折损。见如下示例:
PERFORM create_mv('cs_session_page_requests_mv', my_query); EXECUTE 'UPDATE tbl SET ' || quote_ident(columnname) || ' = ' || quote_literal(newvalue);