在管理表单中保存期间,django会丢失毫秒数

时间:2014-06-12 12:11:00

标签: python mysql django mysql-5.7

我正在使用mysql 5.7 db和django 1.8,据我所知,它们都支持毫秒数。我可以通过mysql进入我的数据库,以HH:MM:SS.fff的形式输入时间。 (例如00:05:45:100)

当我打开django的管理页面时,它会正确显示时间(例如00:05:45:100000)但如果我通过管理表单输入时间并按“保存”,则时间变为例如00:05:45:000000所以在我看来毫秒没有得到保存

为什么会这样,有没有办法改变它? 谢谢

admin.py

from django.contrib import admin
from items.models import Maximum
from django import forms

class MaximumAdminForm(forms.ModelForm):
    def __init__(self, *arg, **kwargs):
        super(MaximumAdminForm, self).__init__(*arg, **kwargs)
        self.fields['time_point'] = forms.TimeField(widget=forms.TimeInput(format="%H:%M:%S.%f")) 

    class Meta:
        model = Maximum
        fields = ['item', 'time_point',]

class MaximumAdmin(admin.ModelAdmin):
    form = MaximumAdminForm

    def milliseconds(self, obj):
        return obj.time_point.strftime("%H:%M:%S.%f")[0:12]    

    milliseconds.short_description = 'time point'
    list_display = ('id', 'milliseconds',)

admin.site.register(Maximum, MaximumAdmin)

1 个答案:

答案 0 :(得分:4)

Django 1.7 currently supports MySQL 5.0.3 and higher的下一个稳定版本并不是所有这些版本都支持微秒。 Django 1.8目前是不稳定的主人,其支持的版本和发布日期尚未确定。因此,后端会截断value_to_db_time中的微秒:

def value_to_db_time(self, value):
    if value is None:
        return None

    # MySQL doesn't support tz-aware times
    if timezone.is_aware(value):
        raise ValueError("MySQL backend does not support timezone-aware times.")

    # MySQL doesn't support microseconds
    return six.text_type(value.replace(microsecond=0))

这在受支持的数据库文档的the DateTime fields section下注明:

  

MySQL不存储几分之一秒。秒的分数是   存储时间时截断为零。