Waiting for 8.4 – RETURNS TABLE

Pavel Stehule wrote, and Tom Lane committed patch which ads new syntax for set-returning functions: “RETURNS TABLE".

Commit was on 18th of July, and the message was:

Implement SQL-spec RETURNS TABLE syntax for functions.
 
(Unlike the original submission, this patch treats TABLE output parameters
as being entirely equivalent to OUT parameters -- tgl)
 
Pavel Stehule

As you can tell from commit-log, new synatax doesn't give you any new functionality – it's just a syntactic sugar atop existing features.

But, I have to admit that it's a pretty tasty sugar:

CREATE FUNCTION test(max_i INT4) RETURNS TABLE (i INT4, double_i INT8) AS $$
BEGIN
    FOR i IN SELECT generate_series(1, max_i) LOOP
        double_i := i * 2;
        RETURN NEXT;
    END LOOP;
    RETURN;
END;
$$ LANGUAGE plpgsql;

Of course the same could be done using “OUT" parameters:

CREATE FUNCTION test(IN max_i INT4, OUT i INT4, OUT double_i INT8) RETURNS SETOF RECORD AS $$
BEGIN
    FOR i IN SELECT generate_series(1, max_i) LOOP
        double_i := i * 2;
        RETURN NEXT;
    END LOOP;
    RETURN;
END;
$$ LANGUAGE plpgsql;

but I like “RETURNS TABLE" better than out parameters. It's shorter and more readable. Good job.

One thought on “Waiting for 8.4 – RETURNS TABLE”

  1. SQL by default was designed to be syntactic sugar syntax readable for non technical people. the INs and OUTs reminds of Assembly language where programmers should consider how,what and where data should be streamed in a computer. it is good to see more readable syntax. More, it will be better to see a default data type of the same input; where it is possible that the developer consider ” as data type in, as data type out”. The output-Data of a function is the same type of the data-in

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.