Hi Charles, You are right about parameter types. When I use function with cast as you mentioned, I don't see "unknown". I see data types. but still doesn't insert with my custom function. It's really weird cause I did same thing for different function and It works.
Regards, Gunce 2017-03-06 15:22 GMT+03:00 Charles Clavadetscher <clavadetsc...@swisspug.org >: > Hello Günce > > > > *From:* pgsql-general-ow...@postgresql.org [mailto:pgsql-general-owner@ > postgresql.org] *On Behalf Of *Günce Kaya > *Sent:* Montag, 6. März 2017 13:01 > *To:* Charles Clavadetscher <clavadetsc...@swisspug.org> > *Cc:* pgsql-general@postgresql.org > *Subject:* Re: [GENERAL] Fwd: parameter type is unknown error > > > > Hi Charles, > > > > Thank you for your response. I used pg_typeof() function to show > parameters type. > > > > select pg_typeof('asdasdasd'); > > > > result -> "unknown" > > > > Well, a string in single quotes is not necessarily a text: > > > > db=> select pg_typeof('{"hello": "world"}'); > > pg_typeof > > ----------- > > unknown > > (1 row) > > > > db=> select pg_typeof('{"hello": "world"}'::varchar); > > pg_typeof > > ------------------- > > character varying > > (1 row) > > > > db=> select pg_typeof('{"hello": "world"}'::text); > > pg_typeof > > ----------- > > text > > (1 row) > > > > db.archivedb=> select pg_typeof('{"hello": "world"}'::json); > > pg_typeof > > ----------- > > json > > (1 row) > > > > You probably need to specify that your string is a text. > > Bye > > Charles > > > > but I can use this parameter without custom function as successfully and > using cast is doesn't work to get result as successful. > > > > do you have any advice for that? > > > > Regards, > > > > Gunce > > > > 2017-03-06 14:51 GMT+03:00 Charles Clavadetscher < > clavadetsc...@swisspug.org>: > > Hello > > > > *From:* pgsql-general-ow...@postgresql.org [mailto:pgsql-general-owner@ > postgresql.org] *On Behalf Of *Günce Kaya > *Sent:* Montag, 6. März 2017 12:36 > *To:* pgsql-general@postgresql.org > *Subject:* [GENERAL] Fwd: parameter type is unknown error > > > > Hi all, > > > > I created a dummy table and related function that include insert script. > When I execute the function I'm getting error like bellow; > > > > ERROR: function cargo.insertinvoice(integer, integer, integer, *unknown, > unknown, unknown*, integer, timestamp with time zone, integer, integer, > money, timestamp with time zone, timestamp with time zone, timestamp with > time zone) does not exist > > LINE 1: select * from cargo.insertinvoice(1013, 10, 44, 'asda','test... > > ^ > > HINT: No function matches the given name and argument types. You might > need to add explicit type casts. > > > > Table's create script as bellow; > > > > CREATE TABLE cargo.invoice > > ( > > id bigserial NOT NULL, > > orderid integer NOT NULL, > > cargoid integer NOT NULL, > > invoiceowner integer NOT NULL, > > invoiceaddress character(250) NOT NULL, > > receiverfname character varying(50) NOT NULL, > > receiverlname character varying(50) NOT NULL, > > receiverphone integer NOT NULL, > > sendingdatetime timestamp without time zone DEFAULT now(), > > distance real NOT NULL, > > weight numeric NOT NULL, > > addedtax numeric NOT NULL DEFAULT 8, > > invoiceamount money DEFAULT 0, > > cargocreateddate date, > > cargoupdateddate timestamp without time zone, > > cargocancelled timestamp without time zone); > > > > The function that content insert script to cargo.invoice table is > following; > > > > create or replace function cargo.insertinvoice (forderid integer, fcargoid > integer, finvoiceowner integer, finvoiceaddress character, freceiverfname > character varying, freceiverlname character varying, freceiverphone > integer, fsendingdatetime timestamp without time zone, fdistance real, > fweight numeric, finvoiceamount money, fcargocreateddate date, > fcargoupdateddate timestamp, fcargocancelled timestamp without time zone) > returns numeric as $$ > > > > declare v_id bigint; > > > > begin > > > > insert into cargo.invoice (orderid, cargoid, invoiceowner, invoiceaddress, > receiverfname, receiverlname, receiverphone, sendingdatetime, distance, > weight, addedtax, invoiceamount, cargocreateddate, cargoupdateddate, > cargocancelled) > > values(forded, fcargoid, finvoiceowner, finvoiceaddress, > freceiverfname,freceiverlname,freceiverphone, fsendingdatetime, > fdistance, fweight, faddedtax, finvoiceamount, fcargocreateddate, > fcargoupdateddate, fcargocancelled); > > > > select max(id) into v_id from cargo.invoice; > > > > return v_id; > > > > end; > > > > $$ language plpgsql; > > > > > > So, when I execute the function like; > > > > select * from cargo.insertinvoice(1013, 10, 44, 'asda','test1','test2', > 12345, now(), 10000,30, 400, now(), now(), now()); > > > > I'm getting error as you can see in second paragraph even I use cast for > three "unknown" parameter in insert script which is in function , I can not > overcome with this issue so I still get same error. If I use only > following script to insert values to cargo.invoice table, > > > > insert into cargo.invoice ( orderid, cargoid, invoiceowner, > invoiceaddress, receiverfname, receiverlname, receiverphone, > sendingdatetime, distance, weight, addedtax, invoiceamount, > cargocreateddate, cargoupdateddate, cargocancelled) > > values( 1012, 10, 44, 'asdasdasd','xx', 'xxx', 12345, now(), > 10000,30,8,400,now(),now(),now()); > > > > I can insert data successfully. Do you have any idea about that? > > > > One or more parameter don’t have the expected data type. You should check > them in order to find out which ones are giving trouble. > > In the short you may try to cast your calls to now() to timezone without > time stamp: now()::timestamp. > > > > The function now() returns: > > > > db=> select pg_typeof(now()); > > pg_typeof > > -------------------------- > > timestamp with time zone > > (1 row) > > > > And this is different from without time zone. > > > > Hope this helps. > > Bye > > Charles > > > > Any help would be appreciated. > > > > Regards, > > > > -- > > Gunce Kaya > > > > > > -- > > Gunce Kaya > -- Gunce Kaya