Refs #29824 -- Added RangeOperators helper class.

This commit is contained in:
Mads Jensen 2019-07-12 13:08:00 +02:00 committed by Mariusz Felisiak
parent cf79f92abe
commit 7174cf0b00
3 changed files with 53 additions and 8 deletions

View File

@ -12,9 +12,24 @@ __all__ = [
'RangeField', 'IntegerRangeField', 'BigIntegerRangeField', 'RangeField', 'IntegerRangeField', 'BigIntegerRangeField',
'DecimalRangeField', 'DateTimeRangeField', 'DateRangeField', 'DecimalRangeField', 'DateTimeRangeField', 'DateRangeField',
'FloatRangeField', 'FloatRangeField',
'RangeOperators',
] ]
class RangeOperators:
# https://www.postgresql.org/docs/current/functions-range.html#RANGE-OPERATORS-TABLE
EQUAL = '='
NOT_EQUAL = '<>'
CONTAINS = '@>'
CONTAINED_BY = '<@'
OVERLAPS = '&&'
FULLY_LT = '<<'
FULLY_GT = '>>'
NOT_LT = '&>'
NOT_GT = '&<'
ADJACENT_TO = '-|-'
class RangeField(models.Field): class RangeField(models.Field):
empty_strings_allowed = False empty_strings_allowed = False
@ -155,7 +170,7 @@ class DateTimeRangeContains(lookups.PostgresSimpleLookup):
type. type.
""" """
lookup_name = 'contains' lookup_name = 'contains'
operator = '@>' operator = RangeOperators.CONTAINS
def process_rhs(self, compiler, connection): def process_rhs(self, compiler, connection):
# Transform rhs value for db lookup. # Transform rhs value for db lookup.
@ -193,7 +208,7 @@ class RangeContainedBy(lookups.PostgresSimpleLookup):
'date': 'daterange', 'date': 'daterange',
'timestamp with time zone': 'tstzrange', 'timestamp with time zone': 'tstzrange',
} }
operator = '<@' operator = RangeOperators.CONTAINED_BY
def process_rhs(self, compiler, connection): def process_rhs(self, compiler, connection):
rhs, rhs_params = super().process_rhs(compiler, connection) rhs, rhs_params = super().process_rhs(compiler, connection)
@ -220,31 +235,31 @@ models.FloatField.register_lookup(RangeContainedBy)
@RangeField.register_lookup @RangeField.register_lookup
class FullyLessThan(lookups.PostgresSimpleLookup): class FullyLessThan(lookups.PostgresSimpleLookup):
lookup_name = 'fully_lt' lookup_name = 'fully_lt'
operator = '<<' operator = RangeOperators.FULLY_LT
@RangeField.register_lookup @RangeField.register_lookup
class FullGreaterThan(lookups.PostgresSimpleLookup): class FullGreaterThan(lookups.PostgresSimpleLookup):
lookup_name = 'fully_gt' lookup_name = 'fully_gt'
operator = '>>' operator = RangeOperators.FULLY_GT
@RangeField.register_lookup @RangeField.register_lookup
class NotLessThan(lookups.PostgresSimpleLookup): class NotLessThan(lookups.PostgresSimpleLookup):
lookup_name = 'not_lt' lookup_name = 'not_lt'
operator = '&>' operator = RangeOperators.NOT_LT
@RangeField.register_lookup @RangeField.register_lookup
class NotGreaterThan(lookups.PostgresSimpleLookup): class NotGreaterThan(lookups.PostgresSimpleLookup):
lookup_name = 'not_gt' lookup_name = 'not_gt'
operator = '&<' operator = RangeOperators.NOT_GT
@RangeField.register_lookup @RangeField.register_lookup
class AdjacentToLookup(lookups.PostgresSimpleLookup): class AdjacentToLookup(lookups.PostgresSimpleLookup):
lookup_name = 'adjacent_to' lookup_name = 'adjacent_to'
operator = '-|-' operator = RangeOperators.ADJACENT_TO
@RangeField.register_lookup @RangeField.register_lookup

View File

@ -916,3 +916,31 @@ types.
.. attribute:: range_type .. attribute:: range_type
The psycopg2 range type to use. The psycopg2 range type to use.
Range operators
---------------
.. versionadded:: 3.0
.. class:: RangeOperators
PostgreSQL provides a set of SQL operators that can be used together with the
range data types (see `the PostgreSQL documentation for the full details of
range operators <https://www.postgresql.org/docs/current/
functions-range.html#RANGE-OPERATORS-TABLE>`_). This class is meant as a
convenient method to avoid typos. The operator names overlap with the names of
corresponding lookups.
.. code-block:: python
class RangeOperators:
EQUAL = '='
NOT_EQUAL = '<>'
CONTAINS = '@>'
CONTAINED_BY = '<@'
OVERLAPS = '&&'
FULLY_LT = '<<'
FULLY_GT = '>>'
NOT_LT = '&>'
NOT_GT = '&<'
ADJACENT_TO = '-|-'

View File

@ -133,7 +133,9 @@ Minor features
:mod:`django.contrib.postgres` :mod:`django.contrib.postgres`
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* ... * The new :class:`~django.contrib.postgres.fields.RangeOperators` helps to
avoid typos in SQL operators that can be used together with
:class:`~django.contrib.postgres.fields.RangeField`.
:mod:`django.contrib.redirects` :mod:`django.contrib.redirects`
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~