data:image/s3,"s3://crabby-images/835f0/835f0183d68360e38201c0eea348393d05ddc0cf" alt="" |
data:image/s3,"s3://crabby-images/fedd4/fedd46b5eddfc5d215c8fcb543c21c47cbcce0b1" alt="" |
Archives of the TeradataForum
Message Posted: Sat, 07 Aug 2004 @ 10:01:55 GMT
Subj: | | Re: Using a parameter in a macro |
|
From: | | teradatanewsgroup |
Hi Srinivas,
I was not able to test the syntax as I have now no access to an DB but something like the following should work.
create macro sel_age
(
c_o varchar(2),
c_age integer
) as (
ABORT 'Wrong comparison operator has to be =, >, <, >= or <='
WHERE c_o not in ('=','>','<','>=','<=');
select *
from Table_with_age
where (case
when c_o = '=' then
case when age = :c_age then 1 else 0 end
when c_o = '<' then
case when age < :c_age then 1 else 0 end
when c_o = '>' then
case when age > :c_age then 1 else 0 end
when c_o = '>=' then
case when age >= :c_age then 1 else 0 end
when c_o = '<=' then
case when age <= :c_age then 1 else 0 end
else 0
end) = 1
;
);
Kind regards
Ulrich
--
Ulrich Arndt
| |