No title
Why is that I can only cat two variables in a select statement.
ex. select lastname||' '||firstname||' '||address
Delivers an parseing error at "||". When trying
ex. select lastnamae||firstname
It works fine.
What's up?
Doug...
[Charset iso-8859-1 unsupported, filtering to ASCII...]
Why is that I can only cat two variables in a select statement.
ex. select lastname||' '||firstname||' '||address
Delivers an parseing error at "||". When trying
ex. select lastnamae||firstname
It works fine.
What's up?
Doug...
It is a know problem on the TODO list. We don't have a fix for 6.4 yet,
and at this point, it would have to be in a post-6.4 release. If
someone wants to take it on, go ahead. It is a parser problem.
--
Bruce Momjian | http://www.op.net/~candle
maillist@candle.pha.pa.us | (610) 853-3000
+ If your life is a hard drive, | 830 Blythe Avenue
+ Christ can be your backup. | Drexel Hill, Pennsylvania 19026
ex. select lastname||' '||firstname||' '||address
It's because the parser has no defined precedence for operators like ||.
Try:
select (((lastname || ' ') || firstname) || ' ') || address;
Yes, I know it's annoying. But there's a problem with defining precedence in
the grammar for operators like this. Sorry.
Taral
Why is that I can only cat two variables in a select statement.ex.
select lastname||' '||firstname||' '||address
Delivers an parseing error at "||". When tryingex. select
lastnamae||firstnameIt works fine.What's up?Doug...
Hi Doug,
The || operator operates more like a functiion than an operator. What I
mean by that is that, as you have surmised, it takes two and only two
arguments. This does not mean that you cannot concatenate more than two
strings...you just need to use parenthesis in the proper way. Your
query would become:
select ((((lastname||' ')||firstname)||' ')||address
Of course you would need the rest of your query (I assume that was just
the half that was giving you trouble).
Hope this helps...james