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