mirror of https://github.com/django/django.git
[2.0.x] Refs #28643 -- Reorganized database functions docs.
Thanks Tim Graham for the review.
Backport of ad8036d715
from master
This commit is contained in:
parent
edd3601be6
commit
8b42a18b2d
|
@ -23,8 +23,13 @@ We don't usually recommend allowing ``null=True`` for ``CharField`` since this
|
|||
allows the field to have two "empty values", but it's important for the
|
||||
``Coalesce`` example below.
|
||||
|
||||
.. _comparison-functions:
|
||||
|
||||
Comparison and conversion functions
|
||||
===================================
|
||||
|
||||
``Cast``
|
||||
========
|
||||
--------
|
||||
|
||||
.. class:: Cast(expression, output_field)
|
||||
|
||||
|
@ -40,7 +45,7 @@ Usage example::
|
|||
4.0
|
||||
|
||||
``Coalesce``
|
||||
============
|
||||
------------
|
||||
|
||||
.. class:: Coalesce(*expressions, **extra)
|
||||
|
||||
|
@ -80,39 +85,8 @@ Usage examples::
|
|||
>>> now = timezone.now()
|
||||
>>> Coalesce('updated', Cast(now, DateTimeField()))
|
||||
|
||||
``Concat``
|
||||
==========
|
||||
|
||||
.. class:: Concat(*expressions, **extra)
|
||||
|
||||
Accepts a list of at least two text fields or expressions and returns the
|
||||
concatenated text. Each argument must be of a text or char type. If you want
|
||||
to concatenate a ``TextField()`` with a ``CharField()``, then be sure to tell
|
||||
Django that the ``output_field`` should be a ``TextField()``. Specifying an
|
||||
``output_field`` is also required when concatenating a ``Value`` as in the
|
||||
example below.
|
||||
|
||||
This function will never have a null result. On backends where a null argument
|
||||
results in the entire expression being null, Django will ensure that each null
|
||||
part is converted to an empty string first.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> # Get the display name as "name (goes_by)"
|
||||
>>> from django.db.models import CharField, Value as V
|
||||
>>> from django.db.models.functions import Concat
|
||||
>>> Author.objects.create(name='Margaret Smith', goes_by='Maggie')
|
||||
>>> author = Author.objects.annotate(
|
||||
... screen_name=Concat(
|
||||
... 'name', V(' ('), 'goes_by', V(')'),
|
||||
... output_field=CharField()
|
||||
... )
|
||||
... ).get()
|
||||
>>> print(author.screen_name)
|
||||
Margaret Smith (Maggie)
|
||||
|
||||
``Greatest``
|
||||
============
|
||||
------------
|
||||
|
||||
.. class:: Greatest(*expressions, **extra)
|
||||
|
||||
|
@ -154,7 +128,7 @@ and ``comment.modified``.
|
|||
a sensible minimum value to provide as a default.
|
||||
|
||||
``Least``
|
||||
=========
|
||||
---------
|
||||
|
||||
.. class:: Least(*expressions, **extra)
|
||||
|
||||
|
@ -175,148 +149,11 @@ will result in a database error.
|
|||
The PostgreSQL behavior can be emulated using ``Coalesce`` if you know
|
||||
a sensible maximum value to provide as a default.
|
||||
|
||||
``Length``
|
||||
==========
|
||||
.. _date-functions:
|
||||
|
||||
.. class:: Length(expression, **extra)
|
||||
|
||||
Accepts a single text field or expression and returns the number of characters
|
||||
the value has. If the expression is null, then the length will also be null.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> # Get the length of the name and goes_by fields
|
||||
>>> from django.db.models.functions import Length
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> author = Author.objects.annotate(
|
||||
... name_length=Length('name'),
|
||||
... goes_by_length=Length('goes_by')).get()
|
||||
>>> print(author.name_length, author.goes_by_length)
|
||||
(14, None)
|
||||
|
||||
It can also be registered as a transform. For example::
|
||||
|
||||
>>> from django.db.models import CharField
|
||||
>>> from django.db.models.functions import Length
|
||||
>>> CharField.register_lookup(Length, 'length')
|
||||
>>> # Get authors whose name is longer than 7 characters
|
||||
>>> authors = Author.objects.filter(name__length__gt=7)
|
||||
|
||||
``Lower``
|
||||
=========
|
||||
|
||||
.. class:: Lower(expression, **extra)
|
||||
|
||||
Accepts a single text field or expression and returns the lowercase
|
||||
representation.
|
||||
|
||||
It can also be registered as a transform as described in :class:`Length`.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models.functions import Lower
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> author = Author.objects.annotate(name_lower=Lower('name')).get()
|
||||
>>> print(author.name_lower)
|
||||
margaret smith
|
||||
|
||||
``Now``
|
||||
=======
|
||||
|
||||
.. class:: Now()
|
||||
|
||||
Returns the database server's current date and time when the query is executed,
|
||||
typically using the SQL ``CURRENT_TIMESTAMP``.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models.functions import Now
|
||||
>>> Article.objects.filter(published__lte=Now())
|
||||
<QuerySet [<Article: How to Django>]>
|
||||
|
||||
.. admonition:: PostgreSQL considerations
|
||||
|
||||
On PostgreSQL, the SQL ``CURRENT_TIMESTAMP`` returns the time that the
|
||||
current transaction started. Therefore for cross-database compatibility,
|
||||
``Now()`` uses ``STATEMENT_TIMESTAMP`` instead. If you need the transaction
|
||||
timestamp, use :class:`django.contrib.postgres.functions.TransactionNow`.
|
||||
|
||||
``StrIndex``
|
||||
============
|
||||
|
||||
.. class:: StrIndex(string, substring, **extra)
|
||||
|
||||
.. versionadded:: 2.0
|
||||
|
||||
Returns a positive integer corresponding to the 1-indexed position of the first
|
||||
occurrence of ``substring`` inside ``string``, or 0 if ``substring`` is not
|
||||
found.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models import Value as V
|
||||
>>> from django.db.models.functions import StrIndex
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> Author.objects.create(name='Smith, Margaret')
|
||||
>>> Author.objects.create(name='Margaret Jackson')
|
||||
>>> Author.objects.filter(name='Margaret Jackson').annotate(
|
||||
... smith_index=StrIndex('name', V('Smith'))
|
||||
... ).get().smith_index
|
||||
0
|
||||
>>> authors = Author.objects.annotate(
|
||||
... smith_index=StrIndex('name', V('Smith'))
|
||||
... ).filter(smith_index__gt=0)
|
||||
<QuerySet [<Author: Margaret Smith>, <Author: Smith, Margaret>]>
|
||||
|
||||
.. warning::
|
||||
|
||||
In MySQL, a database table's :ref:`collation<mysql-collation>` determines
|
||||
whether string comparisons (such as the ``expression`` and ``substring`` of
|
||||
this function) are case-sensitive. Comparisons are case-insensitive by
|
||||
default.
|
||||
|
||||
``Substr``
|
||||
==========
|
||||
|
||||
.. class:: Substr(expression, pos, length=None, **extra)
|
||||
|
||||
Returns a substring of length ``length`` from the field or expression starting
|
||||
at position ``pos``. The position is 1-indexed, so the position must be greater
|
||||
than 0. If ``length`` is ``None``, then the rest of the string will be returned.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> # Set the alias to the first 5 characters of the name as lowercase
|
||||
>>> from django.db.models.functions import Substr, Lower
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> Author.objects.update(alias=Lower(Substr('name', 1, 5)))
|
||||
1
|
||||
>>> print(Author.objects.get(name='Margaret Smith').alias)
|
||||
marga
|
||||
|
||||
``Upper``
|
||||
=========
|
||||
|
||||
.. class:: Upper(expression, **extra)
|
||||
|
||||
Accepts a single text field or expression and returns the uppercase
|
||||
representation.
|
||||
|
||||
It can also be registered as a transform as described in :class:`Length`.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models.functions import Upper
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> author = Author.objects.annotate(name_upper=Upper('name')).get()
|
||||
>>> print(author.name_upper)
|
||||
MARGARET SMITH
|
||||
|
||||
Date Functions
|
||||
Date functions
|
||||
==============
|
||||
|
||||
.. module:: django.db.models.functions.datetime
|
||||
|
||||
We'll be using the following model in examples of each function::
|
||||
|
||||
class Experiment(models.Model):
|
||||
|
@ -556,6 +393,26 @@ way, and takes priority over an active timezone::
|
|||
... )
|
||||
{'day': 16, 'weekday': 3, 'hour': 9}
|
||||
|
||||
``Now``
|
||||
-------
|
||||
|
||||
.. class:: Now()
|
||||
|
||||
Returns the database server's current date and time when the query is executed,
|
||||
typically using the SQL ``CURRENT_TIMESTAMP``.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models.functions import Now
|
||||
>>> Article.objects.filter(published__lte=Now())
|
||||
<QuerySet [<Article: How to Django>]>
|
||||
|
||||
.. admonition:: PostgreSQL considerations
|
||||
|
||||
On PostgreSQL, the SQL ``CURRENT_TIMESTAMP`` returns the time that the
|
||||
current transaction started. Therefore for cross-database compatibility,
|
||||
``Now()`` uses ``STATEMENT_TIMESTAMP`` instead. If you need the transaction
|
||||
timestamp, use :class:`django.contrib.postgres.functions.TransactionNow`.
|
||||
|
||||
``Trunc``
|
||||
---------
|
||||
|
@ -694,61 +551,6 @@ that deal with date-parts can be used with ``DateField``::
|
|||
2016-01-01 00:00:00+11:00 1
|
||||
2014-06-01 00:00:00+10:00 1
|
||||
|
||||
``TimeField`` truncation
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
.. versionadded:: 1.11
|
||||
|
||||
.. class:: TruncHour(expression, output_field=None, tzinfo=None, **extra)
|
||||
|
||||
.. attribute:: kind = 'hour'
|
||||
|
||||
.. class:: TruncMinute(expression, output_field=None, tzinfo=None, **extra)
|
||||
|
||||
.. attribute:: kind = 'minute'
|
||||
|
||||
.. class:: TruncSecond(expression, output_field=None, tzinfo=None, **extra)
|
||||
|
||||
.. attribute:: kind = 'second'
|
||||
|
||||
These are logically equivalent to ``Trunc('time_field', kind)``. They truncate
|
||||
all parts of the time up to ``kind`` which allows grouping or filtering times
|
||||
with less precision. ``expression`` can have an ``output_field`` of either
|
||||
``TimeField`` or ``DateTimeField``.
|
||||
|
||||
Since ``TimeField``\s don't have a date component, only ``Trunc`` subclasses
|
||||
that deal with time-parts can be used with ``TimeField``::
|
||||
|
||||
>>> from datetime import datetime
|
||||
>>> from django.db.models import Count, TimeField
|
||||
>>> from django.db.models.functions import TruncHour
|
||||
>>> from django.utils import timezone
|
||||
>>> start1 = datetime(2014, 6, 15, 14, 30, 50, 321, tzinfo=timezone.utc)
|
||||
>>> start2 = datetime(2014, 6, 15, 14, 40, 2, 123, tzinfo=timezone.utc)
|
||||
>>> start3 = datetime(2015, 12, 31, 17, 5, 27, 999, tzinfo=timezone.utc)
|
||||
>>> Experiment.objects.create(start_datetime=start1, start_time=start1.time())
|
||||
>>> Experiment.objects.create(start_datetime=start2, start_time=start2.time())
|
||||
>>> Experiment.objects.create(start_datetime=start3, start_time=start3.time())
|
||||
>>> experiments_per_hour = Experiment.objects.annotate(
|
||||
... hour=TruncHour('start_datetime', output_field=TimeField()),
|
||||
... ).values('hour').annotate(experiments=Count('id'))
|
||||
>>> for exp in experiments_per_hour:
|
||||
... print(exp['hour'], exp['experiments'])
|
||||
...
|
||||
14:00:00 2
|
||||
17:00:00 1
|
||||
|
||||
>>> import pytz
|
||||
>>> melb = pytz.timezone('Australia/Melbourne')
|
||||
>>> experiments_per_hour = Experiment.objects.annotate(
|
||||
... hour=TruncHour('start_datetime', tzinfo=melb),
|
||||
... ).values('hour').annotate(experiments=Count('id'))
|
||||
>>> for exp in experiments_per_hour:
|
||||
... print(exp['hour'], exp['experiments'])
|
||||
...
|
||||
2014-06-16 00:00:00+10:00 2
|
||||
2016-01-01 04:00:00+11:00 1
|
||||
|
||||
``DateTimeField`` truncation
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
|
@ -819,6 +621,213 @@ Usage example::
|
|||
'second': datetime.datetime(2014, 6, 15, 14, 30, 50, tzinfo=<UTC>)
|
||||
}
|
||||
|
||||
``TimeField`` truncation
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
.. versionadded:: 1.11
|
||||
|
||||
.. class:: TruncHour(expression, output_field=None, tzinfo=None, **extra)
|
||||
|
||||
.. attribute:: kind = 'hour'
|
||||
|
||||
.. class:: TruncMinute(expression, output_field=None, tzinfo=None, **extra)
|
||||
|
||||
.. attribute:: kind = 'minute'
|
||||
|
||||
.. class:: TruncSecond(expression, output_field=None, tzinfo=None, **extra)
|
||||
|
||||
.. attribute:: kind = 'second'
|
||||
|
||||
These are logically equivalent to ``Trunc('time_field', kind)``. They truncate
|
||||
all parts of the time up to ``kind`` which allows grouping or filtering times
|
||||
with less precision. ``expression`` can have an ``output_field`` of either
|
||||
``TimeField`` or ``DateTimeField``.
|
||||
|
||||
Since ``TimeField``\s don't have a date component, only ``Trunc`` subclasses
|
||||
that deal with time-parts can be used with ``TimeField``::
|
||||
|
||||
>>> from datetime import datetime
|
||||
>>> from django.db.models import Count, TimeField
|
||||
>>> from django.db.models.functions import TruncHour
|
||||
>>> from django.utils import timezone
|
||||
>>> start1 = datetime(2014, 6, 15, 14, 30, 50, 321, tzinfo=timezone.utc)
|
||||
>>> start2 = datetime(2014, 6, 15, 14, 40, 2, 123, tzinfo=timezone.utc)
|
||||
>>> start3 = datetime(2015, 12, 31, 17, 5, 27, 999, tzinfo=timezone.utc)
|
||||
>>> Experiment.objects.create(start_datetime=start1, start_time=start1.time())
|
||||
>>> Experiment.objects.create(start_datetime=start2, start_time=start2.time())
|
||||
>>> Experiment.objects.create(start_datetime=start3, start_time=start3.time())
|
||||
>>> experiments_per_hour = Experiment.objects.annotate(
|
||||
... hour=TruncHour('start_datetime', output_field=TimeField()),
|
||||
... ).values('hour').annotate(experiments=Count('id'))
|
||||
>>> for exp in experiments_per_hour:
|
||||
... print(exp['hour'], exp['experiments'])
|
||||
...
|
||||
14:00:00 2
|
||||
17:00:00 1
|
||||
|
||||
>>> import pytz
|
||||
>>> melb = pytz.timezone('Australia/Melbourne')
|
||||
>>> experiments_per_hour = Experiment.objects.annotate(
|
||||
... hour=TruncHour('start_datetime', tzinfo=melb),
|
||||
... ).values('hour').annotate(experiments=Count('id'))
|
||||
>>> for exp in experiments_per_hour:
|
||||
... print(exp['hour'], exp['experiments'])
|
||||
...
|
||||
2014-06-16 00:00:00+10:00 2
|
||||
2016-01-01 04:00:00+11:00 1
|
||||
|
||||
.. _text-functions:
|
||||
|
||||
Text functions
|
||||
==============
|
||||
|
||||
``Concat``
|
||||
----------
|
||||
|
||||
.. class:: Concat(*expressions, **extra)
|
||||
|
||||
Accepts a list of at least two text fields or expressions and returns the
|
||||
concatenated text. Each argument must be of a text or char type. If you want
|
||||
to concatenate a ``TextField()`` with a ``CharField()``, then be sure to tell
|
||||
Django that the ``output_field`` should be a ``TextField()``. Specifying an
|
||||
``output_field`` is also required when concatenating a ``Value`` as in the
|
||||
example below.
|
||||
|
||||
This function will never have a null result. On backends where a null argument
|
||||
results in the entire expression being null, Django will ensure that each null
|
||||
part is converted to an empty string first.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> # Get the display name as "name (goes_by)"
|
||||
>>> from django.db.models import CharField, Value as V
|
||||
>>> from django.db.models.functions import Concat
|
||||
>>> Author.objects.create(name='Margaret Smith', goes_by='Maggie')
|
||||
>>> author = Author.objects.annotate(
|
||||
... screen_name=Concat(
|
||||
... 'name', V(' ('), 'goes_by', V(')'),
|
||||
... output_field=CharField()
|
||||
... )
|
||||
... ).get()
|
||||
>>> print(author.screen_name)
|
||||
Margaret Smith (Maggie)
|
||||
|
||||
``Length``
|
||||
----------
|
||||
|
||||
.. class:: Length(expression, **extra)
|
||||
|
||||
Accepts a single text field or expression and returns the number of characters
|
||||
the value has. If the expression is null, then the length will also be null.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> # Get the length of the name and goes_by fields
|
||||
>>> from django.db.models.functions import Length
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> author = Author.objects.annotate(
|
||||
... name_length=Length('name'),
|
||||
... goes_by_length=Length('goes_by')).get()
|
||||
>>> print(author.name_length, author.goes_by_length)
|
||||
(14, None)
|
||||
|
||||
It can also be registered as a transform. For example::
|
||||
|
||||
>>> from django.db.models import CharField
|
||||
>>> from django.db.models.functions import Length
|
||||
>>> CharField.register_lookup(Length, 'length')
|
||||
>>> # Get authors whose name is longer than 7 characters
|
||||
>>> authors = Author.objects.filter(name__length__gt=7)
|
||||
|
||||
``Lower``
|
||||
---------
|
||||
|
||||
.. class:: Lower(expression, **extra)
|
||||
|
||||
Accepts a single text field or expression and returns the lowercase
|
||||
representation.
|
||||
|
||||
It can also be registered as a transform as described in :class:`Length`.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models.functions import Lower
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> author = Author.objects.annotate(name_lower=Lower('name')).get()
|
||||
>>> print(author.name_lower)
|
||||
margaret smith
|
||||
|
||||
``StrIndex``
|
||||
------------
|
||||
|
||||
.. class:: StrIndex(string, substring, **extra)
|
||||
|
||||
.. versionadded:: 2.0
|
||||
|
||||
Returns a positive integer corresponding to the 1-indexed position of the first
|
||||
occurrence of ``substring`` inside ``string``, or 0 if ``substring`` is not
|
||||
found.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models import Value as V
|
||||
>>> from django.db.models.functions import StrIndex
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> Author.objects.create(name='Smith, Margaret')
|
||||
>>> Author.objects.create(name='Margaret Jackson')
|
||||
>>> Author.objects.filter(name='Margaret Jackson').annotate(
|
||||
... smith_index=StrIndex('name', V('Smith'))
|
||||
... ).get().smith_index
|
||||
0
|
||||
>>> authors = Author.objects.annotate(
|
||||
... smith_index=StrIndex('name', V('Smith'))
|
||||
... ).filter(smith_index__gt=0)
|
||||
<QuerySet [<Author: Margaret Smith>, <Author: Smith, Margaret>]>
|
||||
|
||||
.. warning::
|
||||
|
||||
In MySQL, a database table's :ref:`collation<mysql-collation>` determines
|
||||
whether string comparisons (such as the ``expression`` and ``substring`` of
|
||||
this function) are case-sensitive. Comparisons are case-insensitive by
|
||||
default.
|
||||
|
||||
``Substr``
|
||||
----------
|
||||
|
||||
.. class:: Substr(expression, pos, length=None, **extra)
|
||||
|
||||
Returns a substring of length ``length`` from the field or expression starting
|
||||
at position ``pos``. The position is 1-indexed, so the position must be greater
|
||||
than 0. If ``length`` is ``None``, then the rest of the string will be returned.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> # Set the alias to the first 5 characters of the name as lowercase
|
||||
>>> from django.db.models.functions import Substr, Lower
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> Author.objects.update(alias=Lower(Substr('name', 1, 5)))
|
||||
1
|
||||
>>> print(Author.objects.get(name='Margaret Smith').alias)
|
||||
marga
|
||||
|
||||
``Upper``
|
||||
---------
|
||||
|
||||
.. class:: Upper(expression, **extra)
|
||||
|
||||
Accepts a single text field or expression and returns the uppercase
|
||||
representation.
|
||||
|
||||
It can also be registered as a transform as described in :class:`Length`.
|
||||
|
||||
Usage example::
|
||||
|
||||
>>> from django.db.models.functions import Upper
|
||||
>>> Author.objects.create(name='Margaret Smith')
|
||||
>>> author = Author.objects.annotate(name_upper=Upper('name')).get()
|
||||
>>> print(author.name_upper)
|
||||
MARGARET SMITH
|
||||
|
||||
.. _window-functions:
|
||||
|
||||
Window functions
|
||||
|
|
|
@ -423,12 +423,12 @@ Models
|
|||
* A proxy model may now inherit multiple proxy models that share a common
|
||||
non-abstract parent class.
|
||||
|
||||
* Added :class:`~django.db.models.functions.datetime.Extract` functions
|
||||
to extract datetime components as integers, such as year and hour.
|
||||
* Added :class:`~django.db.models.functions.Extract` functions to extract
|
||||
datetime components as integers, such as year and hour.
|
||||
|
||||
* Added :class:`~django.db.models.functions.datetime.Trunc` functions to
|
||||
truncate a date or datetime to a significant component. They enable queries
|
||||
like sales-per-day or sales-per-hour.
|
||||
* Added :class:`~django.db.models.functions.Trunc` functions to truncate a date
|
||||
or datetime to a significant component. They enable queries like
|
||||
sales-per-day or sales-per-hour.
|
||||
|
||||
* ``Model.__init__()`` now sets values of virtual fields from its keyword
|
||||
arguments.
|
||||
|
@ -894,8 +894,8 @@ Miscellaneous
|
|||
yourself.
|
||||
|
||||
* Private expressions ``django.db.models.expressions.Date`` and ``DateTime``
|
||||
are removed. The new :class:`~django.db.models.functions.datetime.Trunc`
|
||||
expressions provide the same functionality.
|
||||
are removed. The new :class:`~django.db.models.functions.Trunc` expressions
|
||||
provide the same functionality.
|
||||
|
||||
* The ``_base_manager`` and ``_default_manager`` attributes are removed from
|
||||
model instances. They remain accessible on the model class.
|
||||
|
|
|
@ -330,16 +330,16 @@ Models
|
|||
(This validator moved to the form field in :doc:`Django 1.11.2 <1.11.2>`.)
|
||||
|
||||
* Added support for time truncation to
|
||||
:class:`~django.db.models.functions.datetime.Trunc` functions.
|
||||
:class:`~django.db.models.functions.Trunc` functions.
|
||||
|
||||
* Added the :class:`~django.db.models.functions.datetime.ExtractWeek` function
|
||||
to extract the week from :class:`~django.db.models.DateField` and
|
||||
* Added the :class:`~django.db.models.functions.ExtractWeek` function to
|
||||
extract the week from :class:`~django.db.models.DateField` and
|
||||
:class:`~django.db.models.DateTimeField` and exposed it through the
|
||||
:lookup:`week` lookup.
|
||||
|
||||
* Added the :class:`~django.db.models.functions.datetime.TruncTime` function
|
||||
to truncate :class:`~django.db.models.DateTimeField` to its time component
|
||||
and exposed it through the :lookup:`time` lookup.
|
||||
* Added the :class:`~django.db.models.functions.TruncTime` function to truncate
|
||||
:class:`~django.db.models.DateTimeField` to its time component and exposed it
|
||||
through the :lookup:`time` lookup.
|
||||
|
||||
* Added support for expressions in :meth:`.QuerySet.values` and
|
||||
:meth:`~.QuerySet.values_list`.
|
||||
|
|
|
@ -245,20 +245,20 @@ Models
|
|||
:attr:`Meta.get_latest_by <django.db.models.Options.get_latest_by>` now
|
||||
allow ordering by several fields.
|
||||
|
||||
* Added the :class:`~django.db.models.functions.datetime.ExtractQuarter`
|
||||
function to extract the quarter from :class:`~django.db.models.DateField` and
|
||||
* Added the :class:`~django.db.models.functions.ExtractQuarter` function to
|
||||
extract the quarter from :class:`~django.db.models.DateField` and
|
||||
:class:`~django.db.models.DateTimeField`, and exposed it through the
|
||||
:lookup:`quarter` lookup.
|
||||
|
||||
* Added the :class:`~django.db.models.functions.datetime.TruncQuarter`
|
||||
function to truncate :class:`~django.db.models.DateField` and
|
||||
* Added the :class:`~django.db.models.functions.TruncQuarter` function to
|
||||
truncate :class:`~django.db.models.DateField` and
|
||||
:class:`~django.db.models.DateTimeField` to the first day of a quarter.
|
||||
|
||||
* Added the :attr:`~django.db.models.Index.db_tablespace` parameter to
|
||||
class-based indexes.
|
||||
|
||||
* If the database supports a native duration field (Oracle and PostgreSQL),
|
||||
:class:`~django.db.models.functions.datetime.Extract` now works with
|
||||
:class:`~django.db.models.functions.Extract` now works with
|
||||
:class:`~django.db.models.DurationField`.
|
||||
|
||||
* Added the ``of`` argument to :meth:`.QuerySet.select_for_update()`, supported
|
||||
|
|
Loading…
Reference in New Issue