Django模型层之如何开启事务、常见的字段类型和参数、ORM字段参数、关系字段

【1】事务

事务的目的:保证多个SQL语句要么同时成功,要么同时失败

事务的4个特性:原子性、一致性、间隔性、持久性

事务的三个方法:

1、transaction ---------- 开启事务

2、rollback -------- 回滚

3、commit --------- 提交

【1.1】开启事务

python 复制代码
from django.db import transaction

try:
    # 开启事务
    with transaction.atomic():
        SQL1
        SQL2
        SQL3
except Exception as e:
    print(e)    #记录日志

    transaction.rollback()

【2】常见的字段类型和参数

|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| 字段类型 | 解释及参数 |
| AutoField | int自增列,参数primary_key=True(必填),如果model中没有自增列,会自动创建一个名为id的列 |
| TntegerField | 整数类型,范围在-2147483648 ~ 2147483647 |
| CharField | 字符类型,参数max_length(必填),max_length表示参数 |
| DateField | 日期字段,日期格式:YYYY-MM-DD,年月日 |
| DateTimeField | 日期字段,格式:YYYY-MM-DD HH:MM:ss\[.uuuuuu]TZ,年月日时分秒 |
| BigAutoField(AutoField) | bigint自增列,必须填入参数 primary_key=True |
| SmallIntegerField(IntegerField) | - 小整数 范围:-32768 ~ 32767 |
| PositiveSmallIntegerField(PostitiveIntegerRelDbTypeMixin, IntegerField) | 正小整数 范围:0 ~ 32767 |
| BigIntegerField(IntegerField) | 长整型(有符号的)范围:-9223372036854775808 ~ 9223372036854775807 |
| BooleanField(Field) | 布尔值类型 True/False 1/0 |
| TextField(Field) | 字符串,路径保存在数据库,文件上传到指定目录 参数: upload_to ="" 上传文件的保存路径 storage = None 存储组件,默认django.core.files.storage.FileSystemStorage |
| ImageField(FileField) | 字符串:路径保存在数据库,文件上传到指定,目录 参数: upload_to = "" 上传文件的保存路径 storage = None 存储组件,默认django.core.files.storage.FileSystemStorage |
| TimeField(DateTimeCheckMixin,Field) | 时间格式: HH:MM:ss\[.uuuuuu] 时分秒 |
| FloatField(Field) | 浮点型 |
| DecimalField(Field) | 10进制小数 参数: max_digits --------- 小数总长度 decimal_places --------小数位长度 |
| BinaryField(Field) | 二进制类型 |

【3】ORM字段参数

  • null
    • 用于表示某个字段为空
  • unique
    • 如果设置为unique=True 则该字段在此表中必须是唯一的
  • db_index
    • 如果db_index=True 则代表着为此字段设置索引
  • default
    • 为该字段设置默认值
  • DateField和DateTimeField
    • 参数:auto_now_add
      • 配置auto_now_add=True,创建数据记录时,会把当前时间添加到数据库
    • 参数:auto_now
      • 配置上auto_now=True,每次更新数据记录的时候会更新该字段

【4】关系字段

【4.1】ForeignKey

外键类型在ORM中用来表示外键关联关系,一般把ForeignKey设置在一对多表关系中多的一方

ForeignKey可以和其它表做关联关系同时也可以和自身做关联关系

【4.2】ForeignKey中设置的属性

  • to
    • 设置要关联的表
  • to_field
    • 设置要关联的表的字段
  • related_name
    • 反向操作时,使用的字段名,用于代替原反向查询时的 " 表名_set "
  • related_query_name
    • 反向查询操作时,使用的连接前缀,用于替换表名
  • on_delete
    • 当删除关联表中的数据时,当前表与其关联的行的行为

【4.3】on_delete的值

  • models.CASCADE
    • 删除关联数据,与之关联也删除
  • models.DO_NOTHING
    • 删除关联数据,引发错误IntegrityError
  • models.PROTECT
    • 删除关联数据,引发错误ProtectedError
  • models.SET_NULL
    • 删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空)
  • models.SET_DEFAULT
    • 删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值)
  • models.SET
    • 删除关联数据
      • 与之关联的值设置为指定值,设置:models.SET(值)
      • 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)

【4.4】db_constraint

  • db_constraint
    • 是否在数据库中创建外键约束,默认为True

【4.5】OneToOneField

  • 一对一表关系
  • 属性
    • to
      • 设置要关联的表
    • to_field
      • 设置要关联的字段
    • on_delete
      • 同ForeignKey字段
相关推荐
渣波9 分钟前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
兵慌码乱10 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
倔强的石头_1 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
倔强的石头_4 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab4 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence5 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神5 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据6 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_6 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡6 天前
【MySQL数据库】数据类型与表约束
数据库·mysql