| From: | Ben Morrow <ben(at)morrow(dot)me(dot)uk> | 
|---|---|
| To: | pgsql-sql(at)postgresql(dot)org | 
| Subject: | Casts in foreign schemas | 
| Date: | 2010-06-08 14:33:27 | 
| Message-ID: | 20100608143327.GA67823@osiris.mauzo.dyndns.org | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-sql | 
Is this behaviour expected? (This is with 8.4.3 on FreeBSD.)
    create schema one;
    set search_path to one;
    create type foo as (x integer);
    create function foo (integer) returns foo
        language plpgsql as $$
            declare
                y foo;
            begin
                y.x = $1;
                return y;
            end
        $$;
    create cast (integer as foo) with function foo (integer);
    grant usage on schema one to public;
    grant execute on function foo (integer) to public;
create schema two;
-- reconnect as a different user
    set search_path to two;
    select 3::one.foo;
    ERROR:  type "foo" does not exist
    CONTEXT:  compilation of PL/pgSQL function "foo" near line 2
    set search_path to two, one;
    select 3::foo;
     foo
    -----
     (3)
    (1 row)
My understanding of things was that PL/pgSQL functions were compiled at
CREATE FUNCTION time, using the SEARCH_PATH currently in effect. Is that
wrong? Is there some GRANT I'm missing that will make this work?
Ben
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Tom Lane | 2010-06-08 14:50:42 | Re: Casts in foreign schemas | 
| Previous Message | reyman | 2010-06-07 22:25:42 | Re: Multiple subquery with insert into command ? |