summaryrefslogtreecommitdiff
path: root/django/db/backends/sqlite3
diff options
context:
space:
mode:
Diffstat (limited to 'django/db/backends/sqlite3')
-rw-r--r--django/db/backends/sqlite3/base.py22
-rw-r--r--django/db/backends/sqlite3/operations.py18
2 files changed, 26 insertions, 14 deletions
diff --git a/django/db/backends/sqlite3/base.py b/django/db/backends/sqlite3/base.py
index 608a2b2a95..13b78edc52 100644
--- a/django/db/backends/sqlite3/base.py
+++ b/django/db/backends/sqlite3/base.py
@@ -213,13 +213,13 @@ class DatabaseWrapper(BaseDatabaseWrapper):
else:
create_deterministic_function = conn.create_function
create_deterministic_function('django_date_extract', 2, _sqlite_datetime_extract)
- create_deterministic_function('django_date_trunc', 2, _sqlite_date_trunc)
+ create_deterministic_function('django_date_trunc', 4, _sqlite_date_trunc)
create_deterministic_function('django_datetime_cast_date', 3, _sqlite_datetime_cast_date)
create_deterministic_function('django_datetime_cast_time', 3, _sqlite_datetime_cast_time)
create_deterministic_function('django_datetime_extract', 4, _sqlite_datetime_extract)
create_deterministic_function('django_datetime_trunc', 4, _sqlite_datetime_trunc)
create_deterministic_function('django_time_extract', 2, _sqlite_time_extract)
- create_deterministic_function('django_time_trunc', 2, _sqlite_time_trunc)
+ create_deterministic_function('django_time_trunc', 4, _sqlite_time_trunc)
create_deterministic_function('django_time_diff', 2, _sqlite_time_diff)
create_deterministic_function('django_timestamp_diff', 2, _sqlite_timestamp_diff)
create_deterministic_function('django_format_dtdelta', 3, _sqlite_format_dtdelta)
@@ -445,8 +445,8 @@ def _sqlite_datetime_parse(dt, tzname=None, conn_tzname=None):
return dt
-def _sqlite_date_trunc(lookup_type, dt):
- dt = _sqlite_datetime_parse(dt)
+def _sqlite_date_trunc(lookup_type, dt, tzname, conn_tzname):
+ dt = _sqlite_datetime_parse(dt, tzname, conn_tzname)
if dt is None:
return None
if lookup_type == 'year':
@@ -463,13 +463,17 @@ def _sqlite_date_trunc(lookup_type, dt):
return "%i-%02i-%02i" % (dt.year, dt.month, dt.day)
-def _sqlite_time_trunc(lookup_type, dt):
+def _sqlite_time_trunc(lookup_type, dt, tzname, conn_tzname):
if dt is None:
return None
- try:
- dt = backend_utils.typecast_time(dt)
- except (ValueError, TypeError):
- return None
+ dt_parsed = _sqlite_datetime_parse(dt, tzname, conn_tzname)
+ if dt_parsed is None:
+ try:
+ dt = backend_utils.typecast_time(dt)
+ except (ValueError, TypeError):
+ return None
+ else:
+ dt = dt_parsed
if lookup_type == 'hour':
return "%02i:00:00" % dt.hour
elif lookup_type == 'minute':
diff --git a/django/db/backends/sqlite3/operations.py b/django/db/backends/sqlite3/operations.py
index 1f77b3109f..71ef000c93 100644
--- a/django/db/backends/sqlite3/operations.py
+++ b/django/db/backends/sqlite3/operations.py
@@ -77,14 +77,22 @@ class DatabaseOperations(BaseDatabaseOperations):
"""Do nothing since formatting is handled in the custom function."""
return sql
- def date_trunc_sql(self, lookup_type, field_name):
- return "django_date_trunc('%s', %s)" % (lookup_type.lower(), field_name)
+ def date_trunc_sql(self, lookup_type, field_name, tzname=None):
+ return "django_date_trunc('%s', %s, %s, %s)" % (
+ lookup_type.lower(),
+ field_name,
+ *self._convert_tznames_to_sql(tzname),
+ )
- def time_trunc_sql(self, lookup_type, field_name):
- return "django_time_trunc('%s', %s)" % (lookup_type.lower(), field_name)
+ def time_trunc_sql(self, lookup_type, field_name, tzname=None):
+ return "django_time_trunc('%s', %s, %s, %s)" % (
+ lookup_type.lower(),
+ field_name,
+ *self._convert_tznames_to_sql(tzname),
+ )
def _convert_tznames_to_sql(self, tzname):
- if settings.USE_TZ:
+ if tzname and settings.USE_TZ:
return "'%s'" % tzname, "'%s'" % self.connection.timezone_name
return 'NULL', 'NULL'