Re: Function or Field? - Mailing list pgsql-sql

From Ramakrishnan Muralidharan
Subject Re: Function or Field?
Date
Msg-id 02767D4600E59A4487233B23AEF5C59922C2A2@blrmail1.aus.pervasive.com
Whole thread Raw
In response to Function or Field?  (lucas@presserv.org)
List pgsql-sql
Hi
 I have tried with the following example
CREATE TABLE products( id serial primary key, description varchar(50));CREATE TABLE vendding( id serial primary key,
date_date, product integer ); 

insert into products values ( 1 , 'Test product 1'  );
insert into products values ( 2 , 'Test product 2'  );

insert into vendding values( 1 , '2005-05-01' , 1 );
insert into vendding values( 2 , '2005-05-02' , 1 );
insert into vendding values( 3 , '2005-05-03' , 1 );
insert into vendding values( 4 , '2005-05-04' , 1 );
insert into vendding values( 5 , '2005-05-05' , 1 );
insert into vendding values( 6 , '2005-05-06' , 1 );
insert into vendding values( 7 , '2005-05-07' , 1 );
insert into vendding values( 8 , '2005-05-01' , 2 );
insert into vendding values( 9 , '2005-05-02' , 2 );
insert into vendding values( 10 , '2005-05-03' , 2 );
insert into vendding values( 11 , '2005-05-04' , 2 );
insert into vendding values( 12 , '2005-05-05' , 2 );
insert into vendding values( 13 , '2005-05-06' , 2 );
insert into vendding values( 14 , '2005-05-07' , 2 );

SELECT  p.id , p.description , max(v.date_) from products p , vendding v where v.product = p.id
group by  p.id , p.description
order by p.id

The above select statement bring the last vending record for each product. I hope you are looking for this kind of
output..

Regards,
R.Muralidharan

-----Original Message-----
From: pgsql-sql-owner@postgresql.org
[mailto:pgsql-sql-owner@postgresql.org]On Behalf Of lucas@presserv.org
Sent: Tuesday, May 03, 2005 1:47 AM
To: pgsql-sql@postgresql.org
Subject: [SQL] Function or Field?


Hi.
What is the better way to store the last record for a translation???
I.E:The data for the last product vendding.What is better:a) Create a field in "product" table and create a Trigger
(beforeinsert or 
update into vendding table) to alter this field.b) Create a view or function that check the all venddings (in vendding
table)
for the specified product and return the last vendding information?
a)CREATE TABLE products( id serial primary key, description varchar(50), last_vendding date()        --Is correct to
usethis field???);CREATE TABLE vendding( id serial primary key, date_ date, product integer references
(products));CREATETRIGGER TG_change_products_last_vendding_field on table vendding BEFORE 
INSERT OR UPDATE FOR EACH ROW EXECUTE procedure
change_products_last_vendding();
b) CREATE TABLE products (  id serial primary key,  description varchar(50) ); CREATE TABLE vendding(  id serial
primarykey,  date_ date,  product integer references (products) ); CREATE VIEW last_product_change as SELECT * from
venddingorder by date_ desc 
limit 1; --Okay, this view will return the last record and not the last record
for a product... but its a example.

I am asking it becouse I have used CLIPPER(dbase) for my old programs and in
DBASE the view/check function that will check for each select is not
functional. And I need to create a field in all table references, but in DBASE
this fields allways broken and I need to recheck it.

Thank you.

---------------------------(end of broadcast)---------------------------
TIP 8: explain analyze is your friend


pgsql-sql by date:

Previous
From: Patrice Drolet
Date:
Subject: Discordance between the way select is called.
Next
From: Ezequiel Tolnay
Date:
Subject: Re: Calling a stored procedure from another stored procedure...