java - Exception in thread "main" org.postgresql.util.PSQLException: ERROR: relation "ActivitySession" does not exist -


i have function in postgres parse json records called thirdpartydataparse() , looks below

create or replace function thirdpartydataparse() returns text $$ declare  sessionid no scroll cursor select asn."id",asn."userid",asn."activityid",pd."datasourceid",ad."dump"    "development"."activitysession" asn inner join "development"."persondatasource" pd on pd."userid" = asn."userid" inner join "development"."activitysessiondump" ad     on asn."id"=ad."activitysessionid" asn."createdat" between now() - interval '5 days' , now() , pd."datasourceid"=1 read only; titles text default ''; rec record; jsonrec record;  begin  open sessionid; loop  fetch sessionid rec;    if not found         exit ;    end if;    if rec."activityid"=1 , rec."datasourceid"=1     execute 'select $1::json#>''{activities-steps,0}''->>''value'' "steps"' jsonrec using rec."dump";    end if; end loop; return titles; end; $$ language plpgsql; 

i calling function in java like

try (callablestatement propercase = con.preparecall("{? = call thirdpartydataparse() }")) {   propercase.registeroutparameter( 1, types.varchar );   propercase.execute(); } 

but getting below error in console

exception in thread "main" org.postgresql.util.psqlexception: error: relation "activitysession" not exist   where: pl/pgsql function thirdpartydataparse() line 10 @ open     @ org.postgresql.core.v3.queryexecutorimpl.receiveerrorresponse(queryexecutorimpl.java:2453)     @ org.postgresql.core.v3.queryexecutorimpl.processresults(queryexecutorimpl.java:2153)     @ org.postgresql.core.v3.queryexecutorimpl.execute(queryexecutorimpl.java:286)     @ org.postgresql.jdbc.pgstatement.executeinternal(pgstatement.java:432)     @ org.postgresql.jdbc.pgstatement.execute(pgstatement.java:358)     @ org.postgresql.jdbc.pgpreparedstatement.executewithflags(pgpreparedstatement.java:171)     @ org.postgresql.jdbc.pgcallablestatement.executewithflags(pgcallablestatement.java:81)     @ org.postgresql.jdbc.pgpreparedstatement.execute(pgpreparedstatement.java:160)     @ sun.reflect.nativemethodaccessorimpl.invoke0(native method)     @ sun.reflect.nativemethodaccessorimpl.invoke(nativemethodaccessorimpl.java:62)     @ sun.reflect.delegatingmethodaccessorimpl.invoke(delegatingmethodaccessorimpl.java:43)     @ java.lang.reflect.method.invoke(method.java:498)     @ org.postgresql.ds.pgpooledconnection$statementhandler.invoke(pgpooledconnection.java:426)     @ com.sun.proxy.$proxy4.execute(unknown source)     @ oneraise.radis.thread.backgroundtask.thirdpartybackgoundtask.main(thirdpartybackgoundtask.java:173) 

then removed callable statement & tried prepared statement still getting error

my prepared statement code

try (preparedstatement stmt = backgroundobj.getdbconnection(prop).preparestatement("select thirdpartydataparse()")) {     stmt.execute(); } 

exception

exception in thread "main" org.postgresql.util.psqlexception: error: relation "activitysession" not exist   where: pl/pgsql function thirdpartydataparse() line 10 @ open     @ org.postgresql.core.v3.queryexecutorimpl.receiveerrorresponse(queryexecutorimpl.java:2453)     @ org.postgresql.core.v3.queryexecutorimpl.processresults(queryexecutorimpl.java:2153)     @ org.postgresql.core.v3.queryexecutorimpl.execute(queryexecutorimpl.java:286)     @ org.postgresql.jdbc.pgstatement.executeinternal(pgstatement.java:432)     @ org.postgresql.jdbc.pgstatement.execute(pgstatement.java:358)     @ org.postgresql.jdbc.pgpreparedstatement.executewithflags(pgpreparedstatement.java:171)     @ org.postgresql.jdbc.pgpreparedstatement.execute(pgpreparedstatement.java:160)     @ sun.reflect.nativemethodaccessorimpl.invoke0(native method)     @ sun.reflect.nativemethodaccessorimpl.invoke(nativemethodaccessorimpl.java:62)     @ sun.reflect.delegatingmethodaccessorimpl.invoke(delegatingmethodaccessorimpl.java:43)     @ java.lang.reflect.method.invoke(method.java:498)     @ org.postgresql.ds.pgpooledconnection$statementhandler.invoke(pgpooledconnection.java:426)     @ com.sun.proxy.$proxy3.execute(unknown source)     @ oneraise.radis.thread.backgroundtask.thirdpartybackgoundtask.main(thirdpartybackgoundtask.java:173) 

error: relation "activitysession" not exist

the error occurs because table activitysession not exist. names of tables case-sensitive. means example "activitysession" != "activitysession". believe has caused error.

so use real database , table names in query.


Comments

Popular posts from this blog

asynchronous - C# WinSCP .NET assembly: How to upload multiple files asynchronously -

aws api gateway - SerializationException in posting new Records via Dynamodb Proxy Service in API -

asp.net - Problems sending emails from forum -