summaryrefslogtreecommitdiff
path: root/docs/ref/databases.txt
diff options
context:
space:
mode:
authorClaude Paroz <claude@2xlibre.net>2014-08-12 18:14:06 +0200
committerClaude Paroz <claude@2xlibre.net>2014-10-28 15:06:58 +0100
commit22da5f8817ffff3917bcf8a652dce84f382c9202 (patch)
tree11e5888b710ce4969a02d7a1574e3739c7da5f68 /docs/ref/databases.txt
parent9e746c13e81241fbf1ae64ec118edaa491790046 (diff)
Fixed #19716 -- Added support for microseconds with MySQL 5.6.4 and up
Thanks erik@cederstrand.dk for the report and Tim Graham for the review.
Diffstat (limited to 'docs/ref/databases.txt')
-rw-r--r--docs/ref/databases.txt29
1 files changed, 25 insertions, 4 deletions
diff --git a/docs/ref/databases.txt b/docs/ref/databases.txt
index cbc75d6a9c..63cb5f279e 100644
--- a/docs/ref/databases.txt
+++ b/docs/ref/databases.txt
@@ -496,11 +496,32 @@ for the field. This affects :class:`~django.db.models.CharField`,
:class:`~django.db.models.SlugField` and
:class:`~django.db.models.CommaSeparatedIntegerField`.
-DateTime fields
-~~~~~~~~~~~~~~~
+.. _mysql-fractional-seconds:
-MySQL does not store fractions of seconds. Fractions of seconds are truncated
-to zero when the time is stored.
+Fractional seconds support for Time and DateTime fields
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+MySQL 5.6.4 and later can store fractional seconds, provided that the
+column definition includes a fractional indication (e.g. ``DATETIME(6)``).
+Earlier versions do not support them at all.
+
+Django will not upgrade existing columns to include fractional seconds if the
+database server supports it. If you want to enable them on an existing database,
+it's up to you to either manually update the column on the target database, by
+executing a command like::
+
+ ALTER TABLE `your_table` MODIFY `your_datetime_column` DATETIME(6)
+
+or using a :class:`~django.db.migrations.operations.RunSQL` operation in a
+:ref:`data migration <data-migrations>`.
+
+.. versionchanged:: 1.8
+
+ Previously, Django truncated fractional seconds from ``datetime`` and
+ ``time`` values when using the MySQL backend. Now it lets the database
+ decide whether it should drop that part of the value or not. By default, new
+ ``DateTimeField`` or ``TimeField`` columns are now created with fractional
+ seconds support on MySQL 5.6.4 or later.
``TIMESTAMP`` columns
~~~~~~~~~~~~~~~~~~~~~