Re: checking for a NULL date in a partitioned table kills performance - Mailing list pgsql-admin

From Wetmore, Matthew (CTR)
Subject Re: checking for a NULL date in a partitioned table kills performance
Date
Msg-id 17C7D941-73CB-41BF-BE8F-BB2788049F1F@glbcore.com
Whole thread Raw
In response to Re: checking for a NULL date in a partitioned table kills performance  (Scott Ribe <scott_ribe@elevated-dev.com>)
List pgsql-admin

I have had this issue in the past.

 

The real admin fix to this is to have a NULL replacement character that prevents this.

This does a few things:

  1. An index will index on a replacement character ( I use <->)
  2. A join is easier on a replacement character than NULL (Nulls last/first avoided)
  3. Stops all evil NULL rules.

 

We strive to fix things, but the real solution, IMHO, is better arch design and better fundamental understanding of how NULL works.

 

Partitioned tables under 500M-750M rows will always have these performance issues.

 

Great ideas on the workaround’s though, I do understand sometimes you inherit a bad db.

 

 

 

From: Scott Ribe <scott_ribe@elevated-dev.com>
Date: Friday, August 23, 2024 at 8:17 AM
To: Pgsql-admin <pgsql-admin@lists.postgresql.org>
Subject: Re: checking for a NULL date in a partitioned table kills performance

 

> On Aug 23, 2024, at 5:39 AM, Doug Reynolds <mav@wastegate.net> wrote: > > You could try something really ugly where you make a function index that COALESCEs the nulls to 1-1-1900 and use the COALESCE in the query. I don't see

> On Aug 23, 2024, at 5:39 AM, Doug Reynolds <mav@wastegate.net> wrote:
> 
> You could try something really ugly where you make a function index that COALESCEs the nulls to 1-1-1900 and use the COALESCE in the query.
 
I don't see how that could be better than just creating a partial index on it WHERE contract_date IS NULL--and anyway I'm sure you're right that no index would help. No matter what, it seems that sequential scans of all partitions will be required since most rows have it null, and it's not even related to the partition key.
 

pgsql-admin by date:

Previous
From: Doug Reynolds
Date:
Subject: Re: checking for a NULL date in a partitioned table kills performance
Next
From: Scott Ribe
Date:
Subject: Re: checking for a NULL date in a partitioned table kills performance