From: | "Nigel Bishop" <Nigel(dot)Bishop(at)ioko(dot)com> |
---|---|
To: | "Richard Huxton" <dev(at)archonet(dot)com> |
Cc: | <pgsql-sql(at)postgresql(dot)org> |
Subject: | Re: Help writing a piece of SQL |
Date: | 2006-02-03 11:10:13 |
Message-ID: | 72558D9A7573814BB4082A28843E03D402658B13@intyodc01.uk.ioko365.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Thanks for that Richard, it's almost what I'm after:
So where the un and dm exist then return 1 row
Where the un doestn't exist and dm does then return all sendtos' where
the dm exists not just where the un='*'
I hope that makes sense.
Thanks for you help
Nigel Bishop
ioko
T: +44 (0)1904 435 458
M: +44 (0)7881 624 386
F: +44 (0)1904 435 450
E: nigel(dot)bishop(at)ioko(dot)com
W: www.ioko.com
-----Original Message-----
From: Richard Huxton [mailto:dev(at)archonet(dot)com]
Sent: 03 February 2006 11:02
To: Nigel Bishop
Cc: pgsql-sql(at)postgresql(dot)org
Subject: Re: [SQL] Help writing a piece of SQL
Nigel Bishop wrote:
>
> username | domain | sendto
>
+-------------+-------------------------------+-------------------------
> -----
>
> Postmaster | intthit08.uk.rabbit.com | root
> root | intthit08.uk.rabbit.com | is-unix(at)rabbit(dot)com
> stoat.griffin | trusting.co.uk |
stoat(dot)griffin(at)rabbit(dot)com
> stoat.griffin | trusting.com |
stoat(dot)griffin(at)rabbit(dot)com
> stoat.griffin | rusty.co.uk |
stoat(dot)griffin(at)rabbit(dot)com
> stoat.griffin | rusty.com |
stoat(dot)griffin(at)rabbit(dot)com
> * | trusting.com | rusty(at)rabbit(dot)com
> * | trusting.co.uk | rusty(at)rabbit(dot)com
> * | rusty.co.uk | rusty(at)rabbit(dot)com
> * | rusty.com | rusty(at)rabbit(dot)com
> The query will have the username and domain passed in as variables.
> If the username and domain exist then return the sendto
> The bit I'm struggling with is if the username doesn't exist then
return
> the sendto where the domain exists
>
> e.g. username=fred (this doesn't exist) and domain=rusty.com then
> return rusty(at)rabbit(dot)com, matilda(dot)clematis(at)rabbit(dot)com,
> stoat(dot)griffin(at)rabbit(dot)com
So: if the username doesn't exist then you return ALL rows with a
matching domain? Not just username="*"?
I'm guessing I've mis-understood and you just want username="*", which
would be something like this:
SELECT sendto, 1 AS priority FROM tbl WHERE username=$1 AND domain=$2
UNION ALL
SELECT sendto, 2 AS priority FROM tbl WHERE username='*' AND domain=$2
ORDER BY priority
LIMIT 1;
Does that help at all?
--
Richard Huxton
Archonet Ltd
Communications on or through ioko's computer systems may be monitored or recorded to secure effective system operation and for other lawful purposes.
Unless otherwise agreed expressly in writing, this communication is to be treated as confidential and the information in it may not be used or disclosed except for the purpose for which it has been sent. If you have reason to believe that you are not the intended recipient of this communication, please contact the sender immediately. No employee is authorised to conclude any binding agreement on behalf of ioko with another party by e-mail without prior express written confirmation.
ioko365 Ltd. VAT reg 656 2443 31. Reg no 3048367. All rights reserved.
From | Date | Subject | |
---|---|---|---|
Next Message | Niklas Johansson | 2006-02-03 12:59:46 | Re: Help writing a piece of SQL |
Previous Message | Richard Huxton | 2006-02-03 11:01:34 | Re: Help writing a piece of SQL |