我正在使用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)
答案 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不存储几分之一秒。秒的分数是 存储时间时截断为零。