On Fri, 2011-03-11 at 08:37 -0500, Bruce Momjian wrote: > Where are we on this?
The options are: 1. Rip out empty ranges. Several people have been skeptical of their usefulness, but I don't recall anyone directly saying that they should be removed. Robert Haas made the point that range types aren't closed under UNION: http://archives.postgresql.org/pgsql-hackers/2011-02/msg01045.php So the additional nice mathematical properties provided by empty ranges are not as important (because it wouldn't be perfect anyway). 2. Change the semantics. Erik Rijkers suggested that we define all operators for empty ranges, perhaps using NULL semantics: http://archives.postgresql.org/pgsql-hackers/2011-02/msg00942.php And Kevin Grittner suggested that there could be discrete ranges of zero length yet a defined starting point: http://archives.postgresql.org/pgsql-hackers/2011-02/msg01042.php 3. Leave empty ranges with the existing "empty set" semantics. Nathan Boley made a good point here: http://archives.postgresql.org/pgsql-hackers/2011-02/msg01108.php Right now it's #3, and I lean pretty strongly toward keeping it. Without #3, people will get confused when fairly simple operations fail in a data-dependent way (at runtime). With #3, people will run into problems only in situations where it is fairly dubious to have an empty range anyway (and therefore likely a real error), such as finding ranges "left of" an empty range. Otherwise, I'd prefer #1 to #2. I think #2 is a bad path to take, and we'll end up with a lot of unintuitive and error-prone operators. Regards, Jeff Davis -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers