[SQL] Create interval using column value?

2004-10-24 Thread Larry Lennhoff
Hi
I have a table (A) with a integer column called build_interval, which 
contains the number of milliseconds betweeen builds.  I have another table 
(B) with a timestamp with timezone column called built_on.  The two tables 
share a column called join_col.  What I want to do is find all the rows in 
A which were built before now() - build_interval seconds ago.  If I could 
just write this in SQL it would look something like:

SELECT A.id FROM A JOIN B ON (join_col) WHERE built_on < now() - interval 
'build_interval seconds';  This does not work at all - I cannot find a way 
to build an interval using a column - casting an integer as an interval is 
forbidden. Can anyone suggest a way to achieve my desired result? I'm not 
wedded to the interval approach.  I can probably change the column type of 
build_interval if necessary.

I am using postgres 7.3.4
Thanks in advance for any help.
---(end of broadcast)---
TIP 9: the planner will ignore your desire to choose an index scan if your
 joining column's datatypes do not match


Re: [SQL] Create interval using column value?

2004-10-24 Thread Tom Lane
Larry Lennhoff <[EMAIL PROTECTED]> writes:
> What I want to do is find all the rows in 
> A which were built before now() - build_interval seconds ago.  If I could 
> just write this in SQL it would look something like:

> SELECT A.id FROM A JOIN B ON (join_col) WHERE built_on < now() - interval 
> 'build_interval seconds';

You are confused about the difference between a literal constant and an
expression.   Try something like

... WHERE built_on < now() - build_interval * interval '1 second';

which relies on the number-times-interval operator.

regards, tom lane

---(end of broadcast)---
TIP 9: the planner will ignore your desire to choose an index scan if your
  joining column's datatypes do not match


Re: [SQL] Create interval using column value?

2004-10-24 Thread Larry Lennhoff
Thanks, that was exactly what I needed.
Larry
]At 11:11 PM 10/24/2004, Tom Lane wrote:
Larry Lennhoff <[EMAIL PROTECTED]> writes:
> What I want to do is find all the rows in
> A which were built before now() - build_interval seconds ago.  If I could
> just write this in SQL it would look something like:
> SELECT A.id FROM A JOIN B ON (join_col) WHERE built_on < now() - interval
> 'build_interval seconds';
You are confused about the difference between a literal constant and an
expression.   Try something like
.. WHERE built_on < now() - build_interval * interval '1 second';
which relies on the number-times-interval operator.
regards, tom lane

---(end of broadcast)---
TIP 2: you can get off all lists at once with the unregister command
   (send "unregister YourEmailAddressHere" to [EMAIL PROTECTED])


Re: [SQL] Create interval using column value?

2004-10-24 Thread Michael Glaesemann
On Oct 25, 2004, at 11:54 AM, Larry Lennhoff wrote:
SELECT A.id FROM A JOIN B ON (join_col) WHERE built_on < now() - 
interval 'build_interval seconds';
It would help to see the error you're getting, but I suspect it has 
something to do with the fact that you're quoting 'build_interval'. Try 
something like WHERE built_on < current_timestamp - build_interval *  
INTERVAL '0.001 second';
(btw, current_timestamp is the SQL standard for now() )

Regards,
Michael Glaesemann
grzm myrealbox com
---(end of broadcast)---
TIP 8: explain analyze is your friend