| From: | David Fetter <david(at)fetter(dot)org> | 
|---|---|
| To: | PG Hackers <pgsql-hackers(at)postgresql(dot)org>, "DBD::Pg" <dbdpg-general(at)svr3(dot)postgresql(dot)org> | 
| Subject: | CSV hack | 
| Date: | 2003-12-10 23:05:34 | 
| Message-ID: | 20031210230534.GA30919@fetter.org | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
Kind people,
I've come up with yet another little hack, this time for turning 1-d
arrays into CSV format.  It's very handy in conjunction with the
array_accum aggregate (can this be made a standard aggregate?) in
<http://developer.postgresql.org/docs/postgres/xaggr.html>.
Here 'tis...
CREATE OR REPLACE FUNCTION csv(anyarray) RETURNS TEXT AS
'DECLARE
    in_array ALIAS FOR $1;
    temp_string TEXT;
    quoted_string TEXT;
    i INTEGER;
BEGIN
    FOR i IN array_lower(in_array, 1)..array_upper(in_array, 1)
    LOOP
        IF in_array[i]::TEXT ~ ''"''
        THEN
            temp_string := ''"'' || replace(in_array[i]::TEXT, ''"'', ''""'')  || ''"'';
        ELSE
            temp_string := in_array[i]::TEXT;
        END IF;
        IF i = array_lower(in_array, 1)
        THEN
            quoted_string := temp_string;
        ELSE
            quoted_string := quoted_string || '','' || temp_string;
        END IF;
    END LOOP;
    RETURN quoted_string;
END;
' LANGUAGE 'plpgsql';
Those DBD::Pg users among us who'd like to be able to bind_columns to
postgresql arrays may have a leg up with Text::CSV_XS.
Other middleware should be able to handle such things, too. :)
Cheers,
D
-- 
David Fetter david(at)fetter(dot)org http://fetter.org/
phone: +1 510 893 6100    cell: +1 415 235 3778
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Joe Conway | 2003-12-11 01:08:19 | Re: CSV hack | 
| Previous Message | Kurt Roeckx | 2003-12-10 22:58:14 | Re: Canonicalization of WHERE clauses considered harmful |