Django框架数据库(mysql)存储时间DateTimeField的用法

前言

        在数据库中存储时间虽然用字符串或者分下来用数字存储就可以解决问题,但是这样要么就是存储空间浪费,要么就是对于时间的运算操作效率很低。而数据库本身就自带了专门存储时间的类型,那在Django框架下如何用数据库存储时间数据呢?

        在mysql里面有个datetime类型,在Django的ORM语言里面对应的类是DateTimieField

        下面就来介绍它的使用方法。

一、存储一个时间数据

首先,声明方式:

    createDate = models.DateTimeField(auto_now_add = True)

 那这个createDate字段的类型就是datetime类型。

这里创建的时候有两个参数auto_now_addauto_now,它们默认都是False,他们的区别如下:

  • 设置为true时,能够在保存该字段时,将其值设置为当前时间,并且每次修改model,都会自动更新。因此这个参数在需要存储“最后修改时间”的场景下,十分方便。需要注意的是,设置该参数为true时,并不简单地意味着字段的默认值为当前时间,而是指字段会被“强制”更新到当前时间,你无法程序中手动为字段赋值;如果使用django自带的admin管理器,那么该字段在admin中是只读的。
  • 设置为true时,auto_now_add会在model对象第一次被创建时,将字段的值设置为创建时的时间,以后修改对象时,字段的值不会再更新。该属性通常被用在存储“创建时间”的场景下。与auto_now类似,auto_now_add也具有强制性,一旦被设置为True,就无法在程序中手动为字段赋值,在admin中字段也会成为只读的。

有一点要注意的是,auto_now_add默认是UTC(可以查看settings.py内TIME_ZONE的设置)时间,即国际标准时间我们是东8区,所以看到的是比当前时间要晚8个小时。这个问题的解决办法是:

settings.py中修改:

TIME_ZONE = 'Asia/Shanghai'
这样存入的时间就是东8区的时间了。

然后就是存储一个数据的时候,因为之前设置了auto_now_add =True,所以我们设置的时候设置属性为None即可:

 然后看看后台:

 没有问题。

二、DateTimeField类型字段数据的获取和常用使用方法

它的用法就和python的datetime类似。

我们可以获取一个记录看看:        

 运行的结果是:

那用法就和datetime.datetime一样了

print("年:"+str(obj.createTime.year)+"月:"+str(obj.createTime.month)+"日:"+str(obj.createTime.day)+"时:"+str(obj.createTime.hour)+"分:"+str(obj.createTime.minute)+"秒:"+str(obj.createTime.second))

结果:

 

总结:

Python和Django真好用。

 

 

        

 

你可能感兴趣的:(Django,Python,python,django,mysql)