summaryrefslogtreecommitdiff
path: root/django/db/backends/mysql/operations.py
diff options
context:
space:
mode:
authorSergey Fedoseev <fedoseev.sergey@gmail.com>2018-10-09 19:38:42 +0500
committerTim Graham <timograham@gmail.com>2018-10-09 10:38:42 -0400
commit3957f767bb215bbd4ca48aabdf068fdd214aa79c (patch)
tree44190f2837c9e949b07446e8f6869370449a818b /django/db/backends/mysql/operations.py
parente90af8bad44341cf8ebd469dac57b61a95667c1d (diff)
downloaddjango-3957f767bb215bbd4ca48aabdf068fdd214aa79c.tar.gz
Simplified handling of DurationField values on MySQL/MariaDB.
Diffstat (limited to 'django/db/backends/mysql/operations.py')
-rw-r--r--django/db/backends/mysql/operations.py9
1 files changed, 1 insertions, 8 deletions
diff --git a/django/db/backends/mysql/operations.py b/django/db/backends/mysql/operations.py
index 973a5548ff..07b5e85ba0 100644
--- a/django/db/backends/mysql/operations.py
+++ b/django/db/backends/mysql/operations.py
@@ -1,4 +1,3 @@
-import decimal
import uuid
from django.conf import settings
@@ -262,12 +261,6 @@ class DatabaseOperations(BaseDatabaseOperations):
def binary_placeholder_sql(self, value):
return '_binary %s' if value is not None and not hasattr(value, 'as_sql') else '%s'
- def convert_durationfield_value(self, value, expression, connection):
- # DurationFields can return a Decimal in MariaDB.
- if isinstance(value, decimal.Decimal):
- value = float(value)
- return super().convert_durationfield_value(value, expression, connection)
-
def subtract_temporals(self, internal_type, lhs, rhs):
lhs_sql, lhs_params = lhs
rhs_sql, rhs_params = rhs
@@ -275,7 +268,7 @@ class DatabaseOperations(BaseDatabaseOperations):
if self.connection.mysql_is_mariadb:
# MariaDB includes the microsecond component in TIME_TO_SEC as
# a decimal. MySQL returns an integer without microseconds.
- return '((TIME_TO_SEC(%(lhs)s) - TIME_TO_SEC(%(rhs)s)) * 1000000)' % {
+ return 'CAST((TIME_TO_SEC(%(lhs)s) - TIME_TO_SEC(%(rhs)s)) * 1000000 AS SIGNED)' % {
'lhs': lhs_sql, 'rhs': rhs_sql
}, lhs_params + rhs_params
return (