iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Django中外键使用总结
  • 487
分享到

Django中外键使用总结

2024-04-02 19:04:59 487人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录了解外键使用外键在同一个app中使用外键外间删除操作的参数意思:在写项目的过程中我们不可避免的会使用到外键这个东西,那么Django中是怎样来使用外键的呢? 了解外键 在Mysq

在写项目的过程中我们不可避免的会使用到外键这个东西,那么Django中是怎样来使用外键的呢?

了解外键

Mysql中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持外键约束的。外键的存在使得ORM框架在处理表关系的时候异常的强大。mysql数据库默认使用的也是InnoDB引擎。

使用外键

新建一个项目,创建一个article的app,添加至settings中,并且在settings中设置数据库的连接,调至整个项目能运行为止。

类定义为class ForeignKey(to,on_delete,**options)。第一个参数是引用的是哪个模型,第二个参数是在使用外键引用的模型数据被删除了,这个字段该如何处理,比如有CASCADE、SET_NULL等(外键删除各个参数的意思)。这里以一个实际案例来说明。比如有一个CateGory和一个Article两个模型。一个种类下可以包含多篇文章,一个Article只能有一个种类,并且通过外键进行引用。那么相关的示例代码如下:

在同一个app中使用外键

在article中的models中写入代码:

from django.db import models

# Create your models here.
class Category(models.Model):
    name = models.CharField(max_length=100)

class Article(models.Model):
    title = models.CharField(max_length=100)
    content = models.TextField()
    # 是由Category影响Article
    category = models.ForeignKey('Category',on_delete=models.CASCADE)

这里我们就在Article中设置了一个外键category。

以上使用ForeignKey来定义模型之间的关系。即在article的实例中可以通过category属性来操作对应的Category模型。这样使用起来非常的方便。示例代码如下:views中写入

from django.shortcuts import render
from . import models
from django.Http import HttpResponse

# Create your views here.
def index(request):
    
    # 插入数据
    # article = models.Article(title='abc',content='111')
    # category = models.Category(name='最新文章')
    # category.save()
    # article.category = category
    # article.save()

    #读取数据
    article = models.Article.objects.first()
    print(article.category.name)
    return HttpResponse('successful')

在上面代码中把相应的注释去了,就能够进行测试了。

为什么使用了ForeignKey后,就能通过category访问到对应的Catrgory对象呢。因此在底层,Django为Article表添加了一个属性名_id的字段(比如category的字段名称是category_id),这个字段是一个外键,记录着对应的种类的主键。以后通过article.category访问的时候,实际上是先通过category_id找到对应的数据,然后再提取Category表中的这条数据,形成一个模型。

如果想要引用另外一个app的模型,那么应该在传递to参数的时候,使用app.model_name进行指定。例如,如果User和Article不是在同一个app中,那么在引用的时候的示例代码如下:
首先新建一个user的app,并且添加至settings中,在user中的models中写入代码,创建一个User模型

from django.db import models

# Create your models here.
class User(models.Model):
    username = models.CharField(max_length=100)

再在article中的models中添加这个外键,即在Article这个模型中新添加一个属性

# 将user中的User这个模型作为外键
author = models.ForeignKey('user.User',on_delete=models.CASCADE,null=True)

如果模型的外键引用的是本身自己这个模型,那么to参数可以为self,或者是这个模型的名字。在论坛开发中,一般评论都可以进行二级评论,即可以针对另外一个评论进行评论,那么在定义模型的时候就需要使用外键来引用自身。示例代码如下:

class Comment(models.Model):
    content = models.TextField()
    orihin_comment = models.ForeignKey('self',on_delete=models.CASCADE)

这样我们就实现了添加了一个外键引用自身。

外间删除操作的参数意思:

如果一个模型使用了外键。那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下:

  • CASCADE:级联操作。如果外键对应的那条数据被删除了,那么这条数据也会被删除。
  • PROTECT:受保护。即只要这条数据引用了外键的那条数据,那么就不能删除外键的那条数据。如果我们强行删除,Django就会报错。
  • SET_NULL:设置为空。如果外键的那条数据被删除了,那么在本条数据上就将这个字段设置为空。如果设置这个选项,前提是要指定这个字段可以为空。
  • SET_DEFAULT:设置默认值。如果外键的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,== 前提是要指定这个字段一个默认值 ==。
  • SET():如果外键的那条数据被删除了。那么将会获取SET函数中的值来作为这个外键的值。SET函数可以接收一个可以调用的对象(比如函数或者方法),如果是可以调用的对象,那么会将这个对象调用后的结果作为值返回回去。== 可以不用指定默认值 ==
  • DO_NOTHING:不采取任何行为。一切全看数据库级别的约束。

以上这些选项只是Django级别的,数据级别依旧是RESTRICT!

数据库层面的约束有四种:

  • RESTRICT:默认的选项,如果想要删除父表的记录时,而在子表中有关联该父表的记录,则不允许删除父表中的记录;
  • NOACTION:同 RESTRICT效果一样,也是首先先检查外键;
  • CASCADE:父表delete、update的时候,子表会delete、update掉关联记录;
  • SET NULL:父表delete、update的时候,子表会将关联记录的外键字段所在列设为null,所以注意在设计子表时外键不能设为not null;

参考链接:https://www.jb51.net/article/257166.htm

为什么ORM能越过数据库的约束呢?

是因为ORM操作是反过来的,比如我们在ORM模型中设置了on_delete=models.CASCADE,那么在进行删除的时候,如果发现在数据库层面有父表约束着它,使他不能被删除,那么ORM就会先去删除父表,再来删除指定的表,从而达到越过了数据库层面的约束。

到此这篇关于Django中外键使用总结的文章就介绍到这了,更多相关Django 外键内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Django中外键使用总结

本文链接: https://www.lsjlt.com/news/119681.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Django中外键使用总结
    目录了解外键使用外键在同一个app中使用外键外间删除操作的参数意思:在写项目的过程中我们不可避免的会使用到外键这个东西,那么Django中是怎样来使用外键的呢? 了解外键 在MySQ...
    99+
    2022-11-11
  • Django中外键ForeignKey介绍使用
    目录1、on_delete2、related_name3、related_query_name4、外键字段的保存这一篇笔记介绍 Django 系统 model 的外键处理,Forei...
    99+
    2022-11-13
  • Redis 键值设计使用总结
    目录前言Redis使用中不规范的现象Redis 使用业务场景推荐与建议如何设计出优雅的key一、遵循如下几个最佳实践约定二、尽量避免bigkey三、使用恰当的数据类型Redis 缓存在实际应用中的使用建议使用业务规范前言...
    99+
    2023-04-07
    Redis 键值设计 Redis 键值 Redis 键值使用
  • Redis键值设计使用总结
    目录前言Redis使用中不规范的现象Redis 使用业务场景推荐与建议如何设计出优雅的key一、遵循如下几个最佳实践约定二、尽量避免bigkey三、使用恰当的数据类型Redis 缓存...
    99+
    2023-05-14
    Redis 键值设计 Redis 键值 Redis 键值使用
  • MySQL 外键约束和表关系相关总结
    目录外键(Foreign Key)如何确定表关系如何建立表关系一对多关系 - 员工表和部门表多对多一对一表关系总结外键(Foreign Key) 按照上述所说,一张表存储员工信息会极大的浪费资源,重复数据太多,这个...
    99+
    2022-05-18
    MySQL 外键约束 MySQL 表关系
  • SQL之MySQL主外键基本概念和总结
    2.键的分类 2.1 主键 主键是某一行属性或者属性组的唯一标示表。 一个表有且只能有一个主键 保证记录的唯一和主键域的非空 主键也是一个特殊的唯一索引 而主键又分为自然主键和代理主键: 自然主键->该...
    99+
    2016-01-09
    SQL之MySQL主外键基本概念和总结
  • Python中Jupyter notebook快捷键总结
    1、命令模式(按Esc键): Enter:转入编辑模式 Shift-Enter:运行本单元,选中下个单元 Ctrl-Enter:运行本单元 Alt-...
    99+
    2022-11-12
  • C语言中的关键字总结
    本篇内容介绍了“C语言中的关键字总结”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.关键字变更历史1999年12月16日,ISO推出了C9...
    99+
    2023-06-20
  • MySQL 数据库 增删查改、克隆、外键 等操作总结
    目录SQL 字段数据类型查看数据库信息语句SQL 语句创建、删除 数据库 数据表向表中添加、删除 记录、查询记录修改表名,添加、修改、删除 字段,添加唯一约束查看、删除、添加 表中的...
    99+
    2022-11-13
  • 在 MySQL 中使用外键
    让我们了解一下如何在MySQL中使用外键 −InnoDB表支持检查外键约束。不需要外键约束来连接两个表。它可以在定义需要使用的列时使用,用于除InnoDB之外的存储引擎。REFERENCES tableName(colName)没有实际效果...
    99+
    2023-10-22
  • JavaScript关键字this的用法总结
    this 是 JavaScript 中的一个关键字,指向当前的对象,在不同的场合,this 有不同的含义。 全局环境中的this 在全局环境中,this 指向全局对象Global,即...
    99+
    2022-11-13
  • 超实用的Java快捷键(总结)
    如下所示:Ctrl+1或F2快速修复Ctrl+D快捷删除行Shift+Enter 快速切换到下一行,在本行的任何位置都可Ctrl+F11快速运行代码Alt+上下键 快速移动行(可多行)Ctrl+M 将光标焦点所在区域的视图变大Alt+/ 叫...
    99+
    2023-05-31
    java 快捷键 ava
  • Java中transient关键字的详细总结
    目录一、概要介绍   1. 序列化2. 为什么要用transient关键字?3. transient的作用二、transient使用总结三、使用场景一、概要介绍&...
    99+
    2023-05-15
    Java transient关键字 transient关键字 Java transient
  • MYSQL中如何使用外键
    本篇文章给大家分享的是有关MYSQL中如何使用外键,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。外键的使用条件: 1.两个表必须是I...
    99+
    2022-10-18
  • Linux CLI操作常用快捷键总结
    如下所示: 快捷键 作用 ctrl + a (ahead)把光标移动到命令行...
    99+
    2022-06-04
    快捷键 常用 操作
  • w3m使用总结
    ...
    99+
    2023-01-31
    w3m
  • redis 使用总结
    最近一段时间与redis接触比较频繁。发现有些东西还是工作中经常会用到的,自己也花了点时间巩固下。本篇文章主要是以总结性的方式梳理,因为redis的主题很大,任何一个技术点展开都是几篇文章的量。也可以说这篇...
    99+
    2022-10-18
  • sqlite3使用总结
           OS X自从10.4后把SQLite这套相当出名的数据库软件,放进了作业系统工具集里。OS X包装的是第三版的SQLite,又称SQLite3。这套软件有几个特色:软件属于公共财(public domain),SQLite可说...
    99+
    2023-01-31
  • clipboard.js使用总结
    目录(1)介绍: (2)clipboard复印内容的方式有 (3)Function操作有两种: (4)通过属性返回复印的内容 (5)函数和属性的兼容方式 (1)介绍: clipbo...
    99+
    2022-11-12
  • BigDecimal使用总结
    对于超过16位的大型数字,需要用到Java在java.math包中提供的API类BigDecimal,而且也不是传统的+-*/,而是调用对应的方法。 1.创建对象 使用new的方式创建BigDecim...
    99+
    2023-09-03
    java BigDecimal
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作