1
0
mirror of https://github.com/django/django.git synced 2025-10-24 14:16:09 +00:00

[1.10.x] Refs #25774 -- Adjusted datetime database function docs field names.

Backport of 90468079ec from master
This commit is contained in:
Simon Charette
2016-06-18 23:25:12 -04:00
parent fda151e512
commit cf6f0e9978

View File

@@ -304,9 +304,9 @@ Date Functions
We'll be using the following model in examples of each function:: We'll be using the following model in examples of each function::
class Experiment(models.Model): class Experiment(models.Model):
start_time = models.DateTimeField() start_datetime = models.DateTimeField()
start_date = models.DateField(null=True, blank=True) start_date = models.DateField(null=True, blank=True)
end_time = models.DateTimeField(null=True, blank=True) end_datetime = models.DateTimeField(null=True, blank=True)
end_date = models.DateField(null=True, blank=True) end_date = models.DateField(null=True, blank=True)
``Extract`` ``Extract``
@@ -367,16 +367,16 @@ Usage example::
>>> start = datetime(2015, 6, 15) >>> start = datetime(2015, 6, 15)
>>> end = datetime(2015, 7, 2) >>> end = datetime(2015, 7, 2)
>>> Experiment.objects.create( >>> Experiment.objects.create(
... start_time=start, start_date=start.date(), ... start_datetime=start, start_date=start.date(),
... end_time=end, end_date=end.date()) ... end_datetime=end, end_date=end.date())
>>> # Add the experiment start year as a field in the QuerySet. >>> # Add the experiment start year as a field in the QuerySet.
>>> experiment = Experiment.objects.annotate( >>> experiment = Experiment.objects.annotate(
... start_year=Extract('start_time', 'year')).get() ... start_year=Extract('start_datetime', 'year')).get()
>>> experiment.start_year >>> experiment.start_year
2015 2015
>>> # How many experiments completed in the same year in which they started? >>> # How many experiments completed in the same year in which they started?
>>> Experiment.objects.filter( >>> Experiment.objects.filter(
... start_time__year=Extract('end_time', 'year')).count() ... start_datetime__year=Extract('end_datetime', 'year')).count()
1 1
``DateField`` extracts ``DateField`` extracts
@@ -413,8 +413,8 @@ that deal with date-parts can be used with ``DateField``::
>>> start_2015 = datetime(2015, 6, 15, 23, 30, 1, tzinfo=timezone.utc) >>> start_2015 = datetime(2015, 6, 15, 23, 30, 1, tzinfo=timezone.utc)
>>> end_2015 = datetime(2015, 6, 16, 13, 11, 27, tzinfo=timezone.utc) >>> end_2015 = datetime(2015, 6, 16, 13, 11, 27, tzinfo=timezone.utc)
>>> Experiment.objects.create( >>> Experiment.objects.create(
... start_time=start_2015, start_date=start_2015.date(), ... start_datetime=start_2015, start_date=start_2015.date(),
... end_time=end_2015, end_date=end_2015.date()) ... end_datetime=end_2015, end_date=end_2015.date())
>>> Experiment.objects.annotate( >>> Experiment.objects.annotate(
... year=ExtractYear('start_date'), ... year=ExtractYear('start_date'),
... month=ExtractMonth('start_date'), ... month=ExtractMonth('start_date'),
@@ -458,19 +458,19 @@ Each class is also a ``Transform`` registered on ``DateTimeField`` as
>>> start_2015 = datetime(2015, 6, 15, 23, 30, 1, tzinfo=timezone.utc) >>> start_2015 = datetime(2015, 6, 15, 23, 30, 1, tzinfo=timezone.utc)
>>> end_2015 = datetime(2015, 6, 16, 13, 11, 27, tzinfo=timezone.utc) >>> end_2015 = datetime(2015, 6, 16, 13, 11, 27, tzinfo=timezone.utc)
>>> Experiment.objects.create( >>> Experiment.objects.create(
... start_time=start_2015, start_date=start_2015.date(), ... start_datetime=start_2015, start_date=start_2015.date(),
... end_time=end_2015, end_date=end_2015.date()) ... end_datetime=end_2015, end_date=end_2015.date())
>>> Experiment.objects.annotate( >>> Experiment.objects.annotate(
... year=ExtractYear('start_time'), ... year=ExtractYear('start_datetime'),
... month=ExtractMonth('start_time'), ... month=ExtractMonth('start_datetime'),
... day=ExtractDay('start_time'), ... day=ExtractDay('start_datetime'),
... weekday=ExtractWeekDay('start_time'), ... weekday=ExtractWeekDay('start_datetime'),
... hour=ExtractHour('start_time'), ... hour=ExtractHour('start_datetime'),
... minute=ExtractMinute('start_time'), ... minute=ExtractMinute('start_datetime'),
... second=ExtractSecond('start_time'), ... second=ExtractSecond('start_datetime'),
... ).values( ... ).values(
... 'year', 'month', 'day', 'weekday', 'hour', 'minute', 'second', ... 'year', 'month', 'day', 'weekday', 'hour', 'minute', 'second',
... ).get(end_time__year=ExtractYear('start_time')) ... ).get(end_datetime__year=ExtractYear('start_datetime'))
{'year': 2015, 'month': 6, 'day': 15, 'weekday': 2, 'hour': 23, 'minute': 30, 'second': 1} {'year': 2015, 'month': 6, 'day': 15, 'weekday': 2, 'hour': 23, 'minute': 30, 'second': 1}
When :setting:`USE_TZ` is ``True`` then datetimes are stored in the database When :setting:`USE_TZ` is ``True`` then datetimes are stored in the database
@@ -483,11 +483,11 @@ values that are returned::
>>> tzinfo = pytz.timezone('Australia/Melbourne') # UTC+10:00 >>> tzinfo = pytz.timezone('Australia/Melbourne') # UTC+10:00
>>> with timezone.override(tzinfo): >>> with timezone.override(tzinfo):
... Experiment.objects.annotate( ... Experiment.objects.annotate(
... day=ExtractDay('start_time'), ... day=ExtractDay('start_datetime'),
... weekday=ExtractWeekDay('start_time'), ... weekday=ExtractWeekDay('start_datetime'),
... hour=ExtractHour('start_time'), ... hour=ExtractHour('start_datetime'),
... ).values('day', 'weekday', 'hour').get( ... ).values('day', 'weekday', 'hour').get(
... end_time__year=ExtractYear('start_time'), ... end_datetime__year=ExtractYear('start_datetime'),
... ) ... )
{'day': 16, 'weekday': 3, 'hour': 9} {'day': 16, 'weekday': 3, 'hour': 9}
@@ -497,11 +497,11 @@ way, and takes priority over an active timezone::
>>> import pytz >>> import pytz
>>> tzinfo = pytz.timezone('Australia/Melbourne') >>> tzinfo = pytz.timezone('Australia/Melbourne')
>>> Experiment.objects.annotate( >>> Experiment.objects.annotate(
... day=ExtractDay('start_time', tzinfo=melb), ... day=ExtractDay('start_datetime', tzinfo=melb),
... weekday=ExtractWeekDay('start_time', tzinfo=melb), ... weekday=ExtractWeekDay('start_datetime', tzinfo=melb),
... hour=ExtractHour('start_time', tzinfo=melb), ... hour=ExtractHour('start_datetime', tzinfo=melb),
... ).values('day', 'weekday', 'hour').get( ... ).values('day', 'weekday', 'hour').get(
... end_time__year=ExtractYear('start_time'), ... end_datetime__year=ExtractYear('start_datetime'),
... ) ... )
{'day': 16, 'weekday': 3, 'hour': 9} {'day': 16, 'weekday': 3, 'hour': 9}
@@ -564,11 +564,11 @@ Usage example::
>>> from datetime import datetime >>> from datetime import datetime
>>> from django.db.models import Count, DateTimeField >>> from django.db.models import Count, DateTimeField
>>> from django.db.models.functions import Trunc >>> from django.db.models.functions import Trunc
>>> Experiment.objects.create(start_time=datetime(2015, 6, 15, 14, 30, 50, 321)) >>> Experiment.objects.create(start_datetime=datetime(2015, 6, 15, 14, 30, 50, 321))
>>> Experiment.objects.create(start_time=datetime(2015, 6, 15, 14, 40, 2, 123)) >>> Experiment.objects.create(start_datetime=datetime(2015, 6, 15, 14, 40, 2, 123))
>>> Experiment.objects.create(start_time=datetime(2015, 12, 25, 10, 5, 27, 999)) >>> Experiment.objects.create(start_datetime=datetime(2015, 12, 25, 10, 5, 27, 999))
>>> experiments_per_day = Experiment.objects.annotate( >>> experiments_per_day = Experiment.objects.annotate(
... start_day=Trunc('start_time', 'day', output_field=DateTimeField()) ... start_day=Trunc('start_datetime', 'day', output_field=DateTimeField())
... ).values('start_day').annotate(experiments=Count('id')) ... ).values('start_day').annotate(experiments=Count('id'))
>>> for exp in experiments_per_day: >>> for exp in experiments_per_day:
... print(exp['start_day'], exp['experiments']) ... print(exp['start_day'], exp['experiments'])
@@ -576,10 +576,10 @@ Usage example::
2015-06-15 00:00:00 2 2015-06-15 00:00:00 2
2015-12-25 00:00:00 1 2015-12-25 00:00:00 1
>>> experiments = Experiment.objects.annotate( >>> experiments = Experiment.objects.annotate(
... start_day=Trunc('start_time', 'day', output_field=DateTimeField()) ... start_day=Trunc('start_datetime', 'day', output_field=DateTimeField())
... ).filter(start_day=datetime(2015, 6, 15)) ... ).filter(start_day=datetime(2015, 6, 15))
>>> for exp in experiments: >>> for exp in experiments:
... print(exp.start_time) ... print(exp.start_datetime)
... ...
2015-06-15 14:30:50.000321 2015-06-15 14:30:50.000321
2015-06-15 14:40:02.000123 2015-06-15 14:40:02.000123
@@ -610,9 +610,9 @@ that deal with date-parts can be used with ``DateField``::
>>> start1 = datetime(2014, 6, 15, 14, 30, 50, 321, tzinfo=timezone.utc) >>> start1 = datetime(2014, 6, 15, 14, 30, 50, 321, tzinfo=timezone.utc)
>>> start2 = datetime(2015, 6, 15, 14, 40, 2, 123, tzinfo=timezone.utc) >>> start2 = datetime(2015, 6, 15, 14, 40, 2, 123, tzinfo=timezone.utc)
>>> start3 = datetime(2015, 12, 31, 17, 5, 27, 999, tzinfo=timezone.utc) >>> start3 = datetime(2015, 12, 31, 17, 5, 27, 999, tzinfo=timezone.utc)
>>> Experiment.objects.create(start_time=start1, start_date=start1.date()) >>> Experiment.objects.create(start_datetime=start1, start_date=start1.date())
>>> Experiment.objects.create(start_time=start2, start_date=start2.date()) >>> Experiment.objects.create(start_datetime=start2, start_date=start2.date())
>>> Experiment.objects.create(start_time=start3, start_date=start3.date()) >>> Experiment.objects.create(start_datetime=start3, start_date=start3.date())
>>> experiments_per_year = Experiment.objects.annotate( >>> experiments_per_year = Experiment.objects.annotate(
... year=TruncYear('start_date')).values('year').annotate( ... year=TruncYear('start_date')).values('year').annotate(
... experiments=Count('id')) ... experiments=Count('id'))
@@ -625,7 +625,7 @@ that deal with date-parts can be used with ``DateField``::
>>> import pytz >>> import pytz
>>> melb = pytz.timezone('Australia/Melbourne') >>> melb = pytz.timezone('Australia/Melbourne')
>>> experiments_per_month = Experiment.objects.annotate( >>> experiments_per_month = Experiment.objects.annotate(
... month=TruncMonth('start_time', tzinfo=melb)).values('month').annotate( ... month=TruncMonth('start_datetime', tzinfo=melb)).values('month').annotate(
... experiments=Count('id')) ... experiments=Count('id'))
>>> for exp in experiments_per_month: >>> for exp in experiments_per_month:
... print(exp['month'], exp['experiments']) ... print(exp['month'], exp['experiments'])
@@ -677,14 +677,14 @@ Usage example::
>>> from django.utils import timezone >>> from django.utils import timezone
>>> import pytz >>> import pytz
>>> start1 = datetime(2014, 6, 15, 14, 30, 50, 321, tzinfo=timezone.utc) >>> start1 = datetime(2014, 6, 15, 14, 30, 50, 321, tzinfo=timezone.utc)
>>> Experiment.objects.create(start_time=start1, start_date=start1.date()) >>> Experiment.objects.create(start_datetime=start1, start_date=start1.date())
>>> melb = pytz.timezone('Australia/Melbourne') >>> melb = pytz.timezone('Australia/Melbourne')
>>> Experiment.objects.annotate( >>> Experiment.objects.annotate(
... date=TruncDate('start_time'), ... date=TruncDate('start_datetime'),
... day=TruncDay('start_time', tzinfo=melb), ... day=TruncDay('start_datetime', tzinfo=melb),
... hour=TruncHour('start_time', tzinfo=melb), ... hour=TruncHour('start_datetime', tzinfo=melb),
... minute=TruncMinute('start_time'), ... minute=TruncMinute('start_datetime'),
... second=TruncSecond('start_time'), ... second=TruncSecond('start_datetime'),
... ).values('date', 'day', 'hour', 'minute', 'second').get() ... ).values('date', 'day', 'hour', 'minute', 'second').get()
{'date': datetime.date(2014, 6, 15), {'date': datetime.date(2014, 6, 15),
'day': datetime.datetime(2014, 6, 16, 0, 0, tzinfo=<DstTzInfo 'Australia/Melbourne' AEST+10:00:00 STD>), 'day': datetime.datetime(2014, 6, 16, 0, 0, tzinfo=<DstTzInfo 'Australia/Melbourne' AEST+10:00:00 STD>),