当前位置: 首页 > news >正文

修改时间和创建时间的设计问题

记录一次 在django框架开发中遇到问题:

想要的逻辑:

当在保存数据时,create_time字段只会在新建数据时被设置为当前时间,并且之后不会再修改,而modify_time字段在每次保存数据时都会被设置为当前时间也可以为空,表示最后的修改时间。

当我业务逻辑开发完成后我发现在更新一条数据时该数据的创建时间也随之更新了,

最初的字段设计:

create_time = models.DateTimeField(verbose_name="创建时间", auto_now=True)modify_time = models.DateTimeField(verbose_name="修改时间", blank=True, null=True)

发现问题后的设计:

create_time = models.DateTimeField(verbose_name="创建时间", auto_now_add=True)modify_time = models.DateTimeField(verbose_name="修改时间", blank=True, null=True)

修改时间也可以设计成如下:

modify_time=models.DateTimeField(auto_now=True)

原因:

  • auto_now_add: 当新建一条数据时,该字段会自动设置为当前时间,并且仅在创建时更新一次。
  • auto_now: 每次保存该数据时,该字段都会被自动设置为当前时间,用于表示最后的修改时间。

        models.DateTimeField(verbose_name="修改时间", blank=True, null=True)中的 blank=True, null=True 表示对应的数据库字段允许为空值

  • blank=True: 当该字段设置为True时,在创建或修改数据时,该字段可以为空白。也就是说,该字段允许在表单中不填写任何值。在数据库中,空白的值会被保存为NULL

  • null=True: 当该字段设置为True时,该字段在数据库中可以存储NULL值,即没有值的情况。

这两个选项可以独立使用,也可以同时使用。它们的使用场景如下:

  1. blank=Truenull=True: 表示该字段在表单中可以为空白,并且在数据库中可以存储NULL值。适用于允许用户在表单中选择不填写该字段的情况,并且在数据库中该字段可以为空值。

  2. blank=Truenull=False(默认值): 表示该字段在表单中可以为空白,但在数据库中不能存储NULL值。适用于允许用户在表单中选择不填写该字段的情况,但在数据库中该字段不允许为空值。

  3. blank=False(默认值)和null=True: 表示该字段在表单中必须填写值,但在数据库中可以存储NULL值。适用于在表单中要求用户必须填写该字段的情况,但在数据库中该字段允许为空值。

  4. blank=Falsenull=False: 表示该字段在表单中必须填写值,并且在数据库中也不能存储NULL值。适用于在表单中要求用户必须填写该字段,并且在数据库中该字段不能为为空值的情况。

http://www.lryc.cn/news/110167.html

相关文章:

  • CentOS 搭建 Harbor 镜像仓库(图文详解)
  • 【云原生】k8s组件架构介绍与K8s最新版部署
  • 你真的了解什么是生成式AI吗?
  • Linux--高级IO
  • 【C# 基础精讲】C# 开发环境搭建(Visual Studio等)
  • 谷粒商城第九天-解决商品品牌问题以及前后端使用检验框架检验参数
  • Java8函数式接口
  • .Net6 Web Core API --- Autofac -- AOP
  • RocketMQ基本概念和高级原理
  • 小白到运维工程师自学之路 第六十六集 (docker 网络模型)
  • Go和Java实现建造者模式
  • AutoSAR系列讲解(实践篇)11.6-服务映射(自顶向下)
  • EXCEL, 用if({1,0,0} ...) 实现把给定的区域,输出为任意你想要的矩阵,数组区域!
  • c++实现Qt对象树机制
  • 骨传导蓝牙耳机排行榜,精选五款排名最靠前的耳机
  • JDBC用法小结
  • MySQL 数据表在什么情况下容易损坏
  • 【设计模式——学习笔记】23种设计模式——访问者模式Visitor(原理讲解+应用场景介绍+案例介绍+Java代码实现)
  • Ubuntu安装MySQL 8.0与Navicat
  • GB28181智慧可视化指挥控制系统之执法记录仪设计探讨
  • 【SpringBoot】自动配置自动加载controller的原理
  • Docker Enable live
  • 9.物联网操作系统之软件定时器
  • Windows Server 2012 R2 安装 Oracle RAC 11g R2
  • 本地shell无法连接ubuntu,解决办法?
  • 关于openwrt的802.11w 管理帧保护使用
  • centos手动离线安装php,nginx
  • Java基础六 - Collection集合List、Set、Queue,Map
  • k8s nginx+ingress 配置
  • 探索Streamlit中强大而灵活的 st.write() 函数(五):构建丰富多样的应用界面