Skip site navigation (1) Skip section navigation (2)

Peripheral Links

Header And Logo

PostgreSQL
| The world's most advanced open source database.

Site Navigation

Search archives
  Advanced Search

Re: exists and is not null equivalence in query


  • From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
  • To: Raphael Bauduin <rblists(at)gmail(dot)com>
  • Cc: pgsql-sql(at)postgresql(dot)org
  • Subject: Re: exists and is not null equivalence in query
  • Date: Thu, 28 May 2009 11:19:04 -0400
  • Message-id: <9371.1243523944@sss.pgh.pa.us> <text/plain>

Raphael Bauduin <rblists(at)gmail(dot)com> writes:
> select count(t.trame_id) as count, v.voiture_num as voitureNum  from
>   arch_trames t left join voiture v on (v.tag_id=t.tag_id)
> where
> (t.recept_time >= 1243509320691)
> and exists (select v2.voiture_num from voiture v2 where v2.tag_id=v.tag_id)
> group by v.voiture_num  order by v.voiture_num

> Am I right that I can replace the "and exists..." clause by
>   "and v.voiture_num is not null " in this case?

Well, more like "and v.tag_id is not null".  But yes, the EXISTS seems
pretty stupid.  Also, having done that, the left join reduces to a plain
inner join and you don't even need the NOT NULL.  IOW this should just be

select count(t.trame_id) as count, v.voiture_num as voitureNum  from
  arch_trames t join voiture v on (v.tag_id=t.tag_id)
where (t.recept_time >= 1243509320691)
group by v.voiture_num  order by v.voiture_num

			regards, tom lane



Home | Main Index | Thread Index

Privacy Policy | About PostgreSQL
Copyright © 1996 – 2012 PostgreSQL Global Development Group