django-20.添加创建时间DateTimeField

前言

我们在admin后台发布一篇文章的时候,一般会有创建时间和最后更新时间这2个字段,创建时间就是第一次编辑文章的时候自动添加的,最后更新时间就是每次修改文章的内容后自动更新
在models.py建表的时候,设置creat_time和update_time类型为DateTimeField,添加auto_now_add和auto_now参数

DateTimeField

创建django的model时,有DateTimeField、DateField和TimeField三种类型可以用来创建日期字段,其值分别对应着datetime()、date()、time()三中对象。这三个field有着相同的参数auto_now和auto_now_add

auto_now_add 默认值为fals

这个参数的默认值为False,设置为True时,会在model对象第一次被创建时,将字段的值设置为创建时的时间,以后修改对象时,字段的值不会再更新。
该属性通常被用在存储“创建时间”的场景下。与auto_now类似,auto_now_add也具有强制性,一旦被设置为True,就无法在程序中手动为字段赋值,在admin中字段也会成为只读的。

auto_now_add 默认值为fals

这个参数的默认值为false,设置为true时,能够在保存该字段时,将其值设置为当前时间,并且每次修改model,都会自动更新。因此这个参数在需要存储“最后修改时间”的场景下,十分方便。
需要注意的是,设置该参数为true时,并不简单地意味着字段的默认值为当前时间,而是指字段会被“强制”更新到当前时间,你无法程序中手动为字段赋值;
如果使用django自带的admin管理器,那么该字段在admin中是只读的。

在models.py下新建一个Article类,添加tile、body、auth、create_time、update_time字段。CharField是字符串类型,必须要有max_length参数,当正文的文本内容很多时,需使用TextField

class Article(models.Model):
    ‘‘‘文章‘‘‘
    title = models.CharField(max_length=30)  # 标题
    body = models.TextField()                # 正文
    auth = models.CharField(max_length=10)   # 作者
    # 创建时间
    create_time = models.DateTimeField(auto_now_add=True)
    # 最后更新时间
    update_time = models.DateTimeField(auto_now=True)

    def __str__(self):
        return self.__doc__ + "title->" + self.title

当auto_now和auto_now_add被设置为True后,会导致其字段属性editable=False和blank=True的状态。editable=False将导致字段不会被呈现在admin中,blank=Ture表示允许在表单中不输入值

admin.py注册表

在admin.py添加注册表的信息,然后执行下面两句,同步数据库

python manage.py makemigrations
python manage.py migrate

class ControlArticle(admin.ModelAdmin):
    # 显示的字段
    list_display = (‘title‘, ‘body‘, ‘auth‘, ‘create_time‘, ‘update_time‘)
    # 搜索条件
    search_fields = (‘title‘,)

# 注册Article表
admin.site.register(models.Article, ControlArticle)

amdin后台

打开admin后台,新增一条记录

编辑标题、正文、作者之后保存

列表页面显示结果如下,如果重新编辑的话,最后更新时间也会更新

如果获取的当前时间显示和我们的时间相差八个小时,需要在setting.py设置 TIME_ZONE = ‘Asia/Shanghai‘ ,参考前面的一篇https://www.cnblogs.com/yoyoketang/p/10342696.html

TIME_ZONE和USE_TZ

TIME_ZONE是设置时区,如果想获取中国的当前,可以设置 TIME_ZONE = ‘Asia/Shanghai‘,后面获取当前时间会用到。
同时把USE_TZ设置为False,要不然数据库的实际和当前系统时间不一致

# LANGUAGE_CODE = ‘en-us‘
LANGUAGE_CODE = ‘zh-Hans‘    # 设置简体中文,zh-Hant是繁体中文

# TIME_ZONE =‘UTC‘      # 时区
TIME_ZONE = ‘Asia/Shanghai‘

USE_I18N = True

USE_L10N = True

# USE_TZ = True
USE_TZ = False

修改完之后,在admin后台添加一条数据,时间就是当前时间,数据库查询到也是当前时间了

原文地址:https://www.cnblogs.com/jason89/p/10359451.html

时间: 2024-09-30 23:58:22

django-20.添加创建时间DateTimeField的相关文章

python测试开发django-20.添加创建时间DateTimeField

前言 我们在admin后台发布一篇文章的时候,一般会有创建时间和最后更新时间这2个字段,创建时间就是第一次编辑文章的时候自动添加的,最后更新时间就是每次修改文章的内容后自动更新 在models.py建表的时候,设置creat_time和update_time类型为DateTimeField,添加auto_now_add和auto_now参数 DateTimeField 创建django的model时,有DateTimeField.DateField和TimeField三种类型可以用来创建日期字段

mysql 添加时间列(用于记录创建时间和修改时间)

在mysql建表的时候需要添加两个时间列,分别记录当前记录的创建时间和修改时间. 好. 下面是建表语句: [sql] view plain copy DROP TABLE IF EXISTS `mytesttable`; CREATE TABLE `mytesttable` ( `id` int(11) NOT NULL, `name` varchar(255) DEFAULT NULL, `createtime` datetime DEFAULT CURRENT_TIMESTAMP, `upd

Mysql 添加 create_time, update_time 创建时间 更新时间 自动更新

# 添加创建 更新 时间字段 ALTER TABLE `表名` ADD COLUMN `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP AFTER `最后一个列名`, ADD COLUMN `update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP AFTER `create_time`; 执行后, 会批量更新 现有数据全部自动更新为当前时间,  新插入的数据时候自动更新插入

Django ORM (一) 创建数据库和模型常用的字段类型参数及Field 重要参数介绍

创建一个 Django 项目及应用 django-admin startproject orm cd orm python manage.py startapp app01 在 models.py 上创建数据库结构 from django.db import models class Publisher(models.Model): name = models.CharField(max_length=30, verbose_name="名称") address = models.Ch

八、Python Django数据库添加查询

Python Django数据库添加查询 对数据进行操作 一.创建记录 # pwd /root/csvt03 # ipython manage.py shell In [1]: from blog.models import Employee #(第一种方法) In [2]: Employee Out[2]: blog.models.Employee In [3]: emp = Employee() In [4]: emp.name = 'Alen' In [5]: emp.save() #(第

《BI项目笔记》创建时间维度(1)

原文:<BI项目笔记>创建时间维度(1) SSAS Date 维度基本上在所有的 Cube 设计过程中都存在,很难见到没有时间维度的 OLAP 数据库.但是根据不同的项目需求, Date 维度的设计可能不大相同,所以在设计时间维度的时候需要搞清楚几个问题: 你的业务涉及到的最低的细节级别是什么?比如按季度查看报表还是按月份,或者按周,或者再甚者按天.这个细节级别需要弄清楚,比如在一些销售数据统计,有的时候可能更多按季度或者按月来查看报表.但在有的监控一些机器运行数据的统计,可能会按照小时或者分

C# 获取文件大小,创建时间,文件信息,FileInfo类的属性表

C# 获取文件大小,创建时间,文件信息,FileInfo类的属性表 2011-12-13 09:00:40| 分类: C# |举报|字号 订阅 OpenFileDialog openFileDialog1 = new OpenFileDialog(); if(openFileDialog1.ShowDialog() == DialogResult.OK) { openFileDialog1.FileName; System.IO.FileInfo file = new System.IO.Fil

django中添加用户

在django中添加用户,直接在auth_user表中添加会有问题,因为这里密码是加密的,可以通过manage.py shell加入 创建User: 1 >>> from django.contrib.auth.models import User 2 >>> user = User.objects.create_user('esperyong', '[email protected]', '123456') 3 # 现在一个is_active属性为True的User对

Web 在线文件管理器学习笔记与总结(2)显示文件列表(名称,类型,大小,可读,可写,可执行,创建时间,修改时间,访问时间)

主要函数: filetype() 判断文件类型 filesize() 得到文件大小(字节) is_readable() 判断文件是否可读 is_writeable() 判断文件是否可写 is_executable() 判断文件是否可执行 filectime() 文件创建时间 filemtime() 文件修改时间 fileatime() 文件访问时间 file.func.php 封装文件操作的文件: <?php /* 转换字节大小 */ function transByte($size){ $ar