apparent problem with a PL - Mailing list pgsql-sql

From Rajesh Kumar Mallah
Subject apparent problem with a PL
Date
Msg-id 200304191129.39347.mallah@trade-india.com
Whole thread Raw
Responses Re: apparent problem with a PL  (Stephan Szabo <sszabo@megazone23.bigpanda.com>)
List pgsql-sql
Hi,

If I limit  a particular query to show 3 results which has a function call
how can the function get called 4 times ? its apparently happening to me.

tradein_clients=# SELECT company_id, utils.pgxml_xpath_pl('/Company@CompanyId' , xml) from 
companies where xml is not null limit 3;

INFO:  function pgxml_xpath_pl has been called
INFO:  function pgxml_xpath_pl has been called
INFO:  function pgxml_xpath_pl has been called
INFO:  function pgxml_xpath_pl has been called
+------------+----------------+
| company_id | pgxml_xpath_pl |
+------------+----------------+
|         65 | 65             |
|        187 | 187            |
|        382 | 382            |
+------------+----------------+
(3 rows)


but when i filter by a column the behaviour is rite:

tradein_clients=# SELECT company_id, utils.pgxml_xpath_pl('/Company@CompanyId' , xml) from 
companies where xml is not null and company_id=65;
INFO:  function pgxml_xpath_pl has been called
+------------+----------------+
| company_id | pgxml_xpath_pl |
+------------+----------------+
|         65 | 65             |
+------------+----------------+
(1 row)
tradein_clients=#


output of vacuum full verbose analyze  :
( but the faulty behaviour persists)

tradein_clients=# VACUUM FULL Verbose ANALYZE companies ;
INFO:  --Relation public.companies--
INFO:  Pages 385: Changed 0, reaped 377, Empty 0, New 0; Tup 713: Vac 713, Keep/VTL 0/0, UnUsed 2759, MinLen 244,
MaxLen2033; Re-using: Free/Avail. Space 2525848/2524400; EndEmpty/Avail. Pages 0/374.       CPU 0.00s/0.00u sec elapsed
0.00sec.
 
INFO:  Index companies_company_id_key: Pages 15; Tuples 713: Deleted 713.       CPU 0.00s/0.00u sec elapsed 0.00 sec.
INFO:  Index companies_keywordidx: Pages 75; Tuples 555: Deleted 555.       CPU 0.00s/0.00u sec elapsed 0.00 sec.
INFO:  Index companies_email: Pages 34; Tuples 713: Deleted 713.       CPU 0.00s/0.00u sec elapsed 0.00 sec.
INFO:  Rel companies: Pages: 385 --> 77; Tuple(s) moved: 359.       CPU 0.01s/0.05u sec elapsed 0.11 sec.
INFO:  Index companies_company_id_key: Pages 15; Tuples 713: Deleted 359.       CPU 0.00s/0.00u sec elapsed 0.00 sec.
INFO:  Index companies_keywordidx: Pages 75; Tuples 555: Deleted 329.       CPU 0.00s/0.00u sec elapsed 0.00 sec.
INFO:  Index companies_email: Pages 34; Tuples 713: Deleted 359.       CPU 0.00s/0.00u sec elapsed 0.00 sec.
INFO:  --Relation pg_toast.pg_toast_14656776--
INFO:  Pages 300: Changed 300, reaped 0, Empty 0, New 0; Tup 1382: Vac 0, Keep/VTL 0/0, UnUsed 0, MinLen 37, MaxLen
2034;Re-using: Free/Avail. Space 285232/284268; EndEmpty/Avail. Pages 0/289.       CPU 0.00s/0.00u sec elapsed 0.00
sec.
INFO:  Index pg_toast_14656776_index: Pages 16; Tuples 1382.       CPU 0.00s/0.00u sec elapsed 0.01 sec.
INFO:  Rel pg_toast_14656776: Pages: 300 --> 300; Tuple(s) moved: 0.       CPU 0.00s/0.00u sec elapsed 0.00 sec.
INFO:  Analyzing public.companies
VACUUM
tradein_clients=#





CREATE OR REPLACE FUNCTION utils.pgxml_xpath_pl (varchar,text) RETURNS text AS '
use XML::XPath::Simple;

my ($xpath , $xml ) = @_;
my $xp;

elog INFO , "function pgxml_xpath_pl has been called";

eval {       $xp = new XML::XPath::Simple(xml => $xml ,context => "/");
};
if ($@)
{       elog ERROR , "There was an error: $@ ";
}

my $content = $xp->valueof($xpath);

return $content;

' LANGUAGE 'plperlu';

Can anyone shed some light

Regds
Mallah.


-- 
Rajesh Kumar Mallah,
Project Manager (Development)
Infocom Network Limited, New Delhi
phone: +91(11)6152172 (221) (L) ,9811255597 (M)

Visit http://www.trade-india.com ,
India's Leading B2B eMarketplace.



pgsql-sql by date:

Previous
From: Tom Lane
Date:
Subject: Re: Truly bizarre behavior with VACUUM FULL?
Next
From: "A.Bhuvaneswaran"
Date:
Subject: Re: How to retrieve object definition?