From: | Florent THOMAS <mailinglist(at)tdeo(dot)fr> |
---|---|
To: | postgesql general <pgsql-general(at)postgresql(dot)org> |
Cc: | Neil Stlyz <neilstylz(at)yahoo(dot)com> |
Subject: | Re: combine SQL SELECT statements into one |
Date: | 2010-02-01 08:35:24 |
Message-ID: | 1265013324.23250.21.camel@Dell_Inspiron |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general pgsql-novice pgsql-sql |
Hi,
If I were you, I worked like this.
First make a union of those three query
Then make a crosstab :
http://www.postgresonline.com/journal/index.php?/archives/14-CrossTab-Queries-in-PostgreSQL-using-tablefunc-contrib.html
documented here :
http://www.postgresql.org/docs/8.4/interactive/tablefunc.html
Le dimanche 31 janvier 2010 à 23:36 -0800, Neil Stlyz a écrit :
> Good Evening, Good Morning Wherever you are whenever you may be
> reading this.
>
> I am new to this email group and have some good experience with SQL
> and PostgreSQL database.
>
>
> I am currently working on a PHP / PostgreSQL project and I came upon
> something I could not figure out in SQL. I was wondering if anyone
> here could take a look and perhaps offer some guidance or assistance
> in helping me write this SQL query.
>
> Please Consider the following information:
> -------------------------------------------
>
> I have a postgresql table called 'inventory' that includes two fields:
> 'model' which is a character varying field and 'modified' which is a
> timestamp field.
>
> So the table inventory looks something like this:
>
>
> model modified
> ------------- ----------
> I778288176 2010-02-01 08:27:00
> I778288176 2010-01-31 11:23:00
> I778288176 2010-01-29 10:46:00
> JKLM112345 2010-02-01 08:25:00
> JKLM112345 2010-01-31 09:52:00
> JKLM112345 2010-01-28 09:44:00
> X22TUNM765 2010-01-17 10:13:00
> V8893456T6 2010-01-01 09:17:00
>
>
>
> Now with the table, fields and data in mind look at the following
> three queries:
>
>
>
> SELECT COUNT(distinct model) FROM inventory WHERE modified >=
> '2010-02-01';
> SELECT COUNT(distinct model) FROM inventory WHERE modified >=
> '2010-01-20';
> SELECT COUNT(distinct model) FROM inventory WHERE modified >=
> '2010-01-01';
>
>
>
> All three of the above queries work and provide results. However, I
> want to combine the three into one SQL Statement that hits the
> database one time. How can I do this in one SQL Statement? Is it
> possible with sub select?
>
>
>
> Here is what result I am looking for from one SELECT statement using
> the data example from above:
>
>
>
> count1 | count2 | count3
> -------------------------------
> 2 2 4
>
>
> Can this be done with ONE SQL STATEMENT? touching the database only
> ONE time?
>
> Please let me know.
>
>
>
> Thanx> :)
> NEiL
>
>
>
>
>
From | Date | Subject | |
---|---|---|---|
Next Message | A. Kretschmer | 2010-02-01 09:03:28 | Re: combine SQL SELECT statements into one |
Previous Message | Neil Stlyz | 2010-02-01 07:36:55 | combine SQL SELECT statements into one |
From | Date | Subject | |
---|---|---|---|
Next Message | A. Kretschmer | 2010-02-01 09:03:28 | Re: combine SQL SELECT statements into one |
Previous Message | Neil Stlyz | 2010-02-01 07:36:55 | combine SQL SELECT statements into one |
From | Date | Subject | |
---|---|---|---|
Next Message | A. Kretschmer | 2010-02-01 09:03:28 | Re: combine SQL SELECT statements into one |
Previous Message | Neil Stlyz | 2010-02-01 07:36:55 | combine SQL SELECT statements into one |