From: | "A(dot) Kretschmer" <andreas(dot)kretschmer(at)schollglas(dot)com> |
---|---|
To: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: Results per letter query |
Date: | 2007-06-21 10:04:25 |
Message-ID: | 20070621100425.GH1405@a-kretschmer.de |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
am Thu, dem 21.06.2007, um 11:10:02 +0200 mailte Dani Castaños folgendes:
> Hi!
>
> I'm trying to build a query to get if there is an occurrence for a field
> for each alphabetical letter.
> My first thought to know it was to do something like:
>
> SELECT COUNT(field) FROM table WHERE UPPER( field ) LIKE UPPER( 'A%' )
> LIMIT 1;
> SELECT COUNT(field) FROM table WHERE UPPER( field ) LIKE UPPER( 'B%' )
> LIMIT 1;
> SELECT COUNT(field) FROM table WHERE UPPER( field ) LIKE UPPER( 'C%' )
> LIMIT 1;
> ...
> and so on...
>
> Is there any way to do it in only one query??
I'm not sure if i understand you correctly, sorry, if not.
test=*# select * from w;
t
--------
test
foo
bar
foobar
(4 rows)
test=*# select chr(x), count(1) from generate_series(65,90) x, w where
upper(substring (w.t from 1 for 1)) ~ chr(x) group by 1;
chr | count
-----+-------
T | 1
B | 1
F | 2
(3 rows)
Andreas
--
Andreas Kretschmer
Kontakt: Heynitz: 035242/47150, D1: 0160/7141639 (mehr: -> Header)
GnuPG-ID: 0x3FFF606C, privat 0x7F4584DA http://wwwkeys.de.pgp.net
From | Date | Subject | |
---|---|---|---|
Next Message | Dani Castaños | 2007-06-21 10:42:52 | Re: Results per letter query |
Previous Message | A. Kretschmer | 2007-06-21 09:50:25 | Re: [SQL] Select last there dates |