diff options
| author | Claude Paroz <claude@2xlibre.net> | 2014-08-12 18:14:06 +0200 |
|---|---|---|
| committer | Claude Paroz <claude@2xlibre.net> | 2014-10-28 15:06:58 +0100 |
| commit | 22da5f8817ffff3917bcf8a652dce84f382c9202 (patch) | |
| tree | 11e5888b710ce4969a02d7a1574e3739c7da5f68 /docs/ref/databases.txt | |
| parent | 9e746c13e81241fbf1ae64ec118edaa491790046 (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.txt | 29 |
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 ~~~~~~~~~~~~~~~~~~~~~ |
