Re: ORDER BY and NULLs - Mailing list pgsql-sql

From T E Schmitz
Subject Re: ORDER BY and NULLs
Date
Msg-id 414DB594.5000300@numerixtechnology.de
Whole thread Raw
In response to Re: ORDER BY and NULLs  (Jean-Luc Lachance <jllachan@sympatico.ca>)
Responses Re: ORDER BY and NULLs  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-sql
Hello Jean-Luc,
You must've been reading my mind. I was just wondering what to do about 
indexing on that particular table. I read somewhere that an Index is not 
going to improve the performance of an ORDER BY if the sort column 
contains NULLs because NULLs aren't indexed?

For the sake of the example I had simplified matters a wee bit. What I 
really have is:

SELECT * FROM PRODUCT ORDER BY NAME, FROM, TO, FROM2, TO2

FROM, TO, FROM2, TO2 might be NULL. If FROM is NULL, TO will be NULL. If 
FROM2 is NULL, TO2 will be NULL.

How would you index this table?

Kind regards,
Tarlika

Jean-Luc Lachance wrote:

> select ... order by "FROM" is not null, "FROM";
> 
> If you have large amount of rows (with or without nulls) it is faster if 
> use a partial index.
> 
> create index ... on ...("FROM");
> create index ... on ...("FROM") where "FROM" is null;
> 
> 
> JLL
> 
> 
> terry@ashtonwoodshomes.com wrote:
> 
>> Use the coalesce() function.  (coalesce returns the first non-null 
>> value in its list)
>>
>> Specifically
>>
>> ORDER BY coalesce("TO", 0), "FROM"
>>
>> If you have records in "TO" column whose values is LESS then 0, then 
>> you need to replace 0 with
>> something that sorts BEFORE the first most value that your TO result 
>> can return.
>>
>> Terry Fielder
>> Manager Software Development and Deployment
>> Great Gulf Homes / Ashton Woods Homes
>> terry@greatgulfhomes.com
>> Fax: (416) 441-9085
>>
>>
>>
>>> -----Original Message-----
>>> From: pgsql-sql-owner@postgresql.org
>>> [mailto:pgsql-sql-owner@postgresql.org]On Behalf Of T E Schmitz
>>> Sent: Sunday, September 19, 2004 10:58 AM
>>> To: pgsql-sql@postgresql.org
>>> Subject: [SQL] ORDER BY and NULLs
>>>
>>>
>>> Hello,
>>>
>>> I am using PostgreSQL 7.4.2 and as I understand NULL values
>>> always sort
>>> last.
>>>
>>> However, I have a table from which select using two numerical
>>> sort keys
>>> "FROM" and "TO". "TO" might be NULL and I would like to display those
>>> rows first (without sorting the column in descending order).
>>>
>>> Is there any way this can be achieved without inserting bogus values
>>> into that column?
>>>
>>> -- 
>>>
>>>
>>> Regards/Gruß,
>>>
>>> Tarlika Elisabeth Schmitz


pgsql-sql by date:

Previous
From: Tom Lane
Date:
Subject: Re: How to check postgres running or not ?
Next
From: Andrew Sullivan
Date:
Subject: Re: How to check postgres running or not ?