django--ORM表的多對一關係

来源:https://www.cnblogs.com/016681gzz/archive/2022/06/25/16412256.html
-Advertisement-
Play Games

多對一關係是什麼 Django使用django.db.models.ForeignKey定義多對一關係。 ForeignKey需要一個位置參數:與該模型關聯的類 class Info(models.Model): user = models.ForeignKey(other_model,on_del ...


  • 多對一關係是什麼

Django使用django.db.models.ForeignKey定義多對一關係。

ForeignKey需要一個位置參數:與該模型關聯的類

 class Info(models.Model):
       user = models.ForeignKey(other_model,on_delete=models.SET_NULL)

生活中的多對一關係:班主任,班級關係。一個班主任可以帶很多班級,但是每個班級只能有一個班主任

 from django.db import models
 # id name gender 定義老師的模型類
 class Teacher(models.Model):
     name = models.CharField(max_length=30,verbose_name="老師姓名")
     gender = models.CharField(max_length=10,verbose_name="老師性別")
     class Meta:
         db_table = "teachers"
     def __str__(self):
         return self.name
 # id name gender score teacher_id
 class Student(models.Model):
     name = models.CharField(max_length=20,verbose_name="學生姓名")
     gender = models.CharField(max_length=10,verbose_name="學生性別")
     score = models.IntegerField(verbose_name="學生分數")
     # to:後邊寫所關聯的模型類  
     # on_delete=models.CASCADE:主表中數據刪除,從表也刪除
     # 外鍵關聯的是整個模型類,不是單獨的某一個對象
     # 但是通過模型類會產生一個相關聯的欄位 欄位名_id
     teacher = models.ForeignKey(to=Teacher,on_delete=models.CASCADE,verbose_name="所屬老師")
     class Meta:
         db_table = "students"
     def __str__(self):
         return self.name
  • 多對一關係的增刪改操作

 添加老師語法:
  模型類.objects.create()
     Teacher.objects.create(name="王老師",gender="女")
 刪除老師語法:
  模型類.objects.get(條件).delete()
  # 刪除id為2的老師
  Teacher.objects.get(id=2).delete()  # (3, {'myapp.Student': 2, 'myapp.Teacher': 1})
   # 3代表一共刪除的數據個數 Student刪除3條 Teacher刪除1
 修改老師語法:
     模型類.objects.filter(條件).update()
  # 修改id為3的老師性別為女
  Teacher.objects.filter(id=3).update(gender="女")

以上創建了兩條老師數據 由於我們設置外鍵關聯可以為空null=True,所以此時在班級表創建時,可以直接保存,不需要提供老師數據

 添加學生語法:
     模型類.objects.create()
  通過外鍵_id的形式來添加
  Student.objects.create(name="李四",gender="男",score=80,teacher_id=3)
  直接給外鍵賦值一個老師對象
  t1 = Teacher.objects.create(name="李老師",gender="男")
  Student.objects.create(name="李四",gender="男",score=80,teacher=t1)
 刪除學生語法:
  模型類.objects.get(條件).delete()
     Student.objects.get(id=1).delete()
 修改學生語法:
     模型類.objects.filter(條件).update(欄位1,欄位2...)
     Student.objects.get(id=1).update(name="張三")

註意要記得刪除之後要重新獲取一次數據,否則查看到的結果中還是之前獲取到的有老師的班級數據

  • 多對一的正向查詢

將老師分配個班級之後,由於班級表關聯了老師欄位,我們可以通過班級找到對應老師 雖然老師表中沒有關聯班級欄位,

但是也可以通過老師找到他所帶的班級,這種查詢方式也叫作關聯查詢

 # 查詢id為2的學生的老師姓名
  --找到id為2的學生
     stu = Student.objects.get(id=2)
     --找到stu對應的老師    stu.teacher.name
     stu.外鍵.name
  • 多對一的反向查詢

通過模型類名稱後追加一個_set,來實現反向查詢

 反向查詢:通過django的內置屬性來進行查詢  模型類(模型類小寫)_set()可以反向查詢老師名下的所有學生,
     # 查詢id為1的老師的所有學生   --先找到id為1的老師    
     tea = Teacher.objects.get(id=1)    
     --查詢tea老師名下的所有學生  老師對象.模型類_set.all()    
     tea.student_set.all()

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 瞭解響應式原理後對代碼的一點小重構 在操作一個響應式變數的時候,可能會多次去取這個響應式變數的值,這就意味著會多次執行依賴收集中的get,可以用一個局部變數緩存下來,這樣只需要一次get操作. // 比如商城業務中,根據價格篩選不同的商品 data: () => ({ goods: [] }), c ...
  • TypeScript 是一種由微軟開發的自由和開源的編程語言,是一種非常受歡迎的 JavaScript 語言擴展,它也是 JavaScript 的一個超集,而且本質上向這個語言添加了可選的靜態類型和基於類的面向對象編程。它在現有的 JavaScript 語法之上加入了一層類型層,而這一層即使被刪除, ...
  • props傳遞數據 步驟: 首先,在子組件中聲明props選項 其次,在子組件中使用v-bind指令動態綁定屬性,通過插值表達式動態獲取數據 最後,在父組件的template中調用子組件標簽的使用傳遞數據 示例: 在子組件MovieItem.vue中 <template> <div class="s ...
  • 一、什麼是首屏載入 首屏時間(First Contentful Paint),指的是瀏覽器從響應用戶輸入網址地址,到首屏內容渲染完成的時間,此時整個網頁不一定要全部渲染完成,但需要展示當前視窗需要的內容,首屏載入可以說是用戶體驗中最重要的環節 二、載入慢的原因 在頁面渲染的過程,導致載入速度慢的因素 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 背景 等值查找,有數組、列表、HashMap等,已經足夠了,範圍查找,該用什麼數據結構呢?下麵介紹java中非常好用的兩個類TreeMap和ConcurrentSkipListMap。 TreeMap的實現基於紅黑樹 每一棵紅黑樹都是一顆二叉排序樹,又稱二叉查找樹(Binary Search Tre ...
  • 在大部分涉及到資料庫操作的項目裡面,事務控制、事務處理都是一個無法迴避的問題。得益於Spring框架的封裝,業務代碼中進行事務控制操作起來也很簡單,直接加個@Transactional註解即可,大大簡化了對業務代碼的侵入性。那麼對@Transactional事務註解瞭解的夠全面嗎?知道有哪些場景可能... ...
  • 寫在前面 這是我在接觸爬蟲後,寫的第二個爬蟲實例。 也是我在學習python後真正意義上寫的第二個小項目,第一個小項目就是第一個爬蟲了。 我從學習python到現在,也就三個星期不到,平時課程比較多,python是額外學習的,每天學習python的時間也就一個小時左右。 所以我目前對於python也 ...
一周排行
    -Advertisement-
    Play Games
  • Github / Gitee QQ群(1群) : 813100564 / QQ群(2群) : 579033769 視頻教學 介紹 MiniWord .NET Word模板引擎,藉由Word模板和數據簡單、快速生成文件。 Getting Started 安裝 nuget link : https:// ...
  • Array.Sort Array類中相當實用的我認為是Sort方法,相比起冗長的冒泡排序,它的出現讓排序更加的簡化 結果如下: 還可以聲明一個靜態方法用來專門調用指定數組排序,從名為 array 的一維數組中 a 索引處開始,到 b 元素 從小到大排序。 註意: a + b 不能大於 array 的 ...
  • 前言 在上一篇文章CLR類型系統概述里提到,當運行時掛起時, 垃圾回收會執行堆棧遍歷器(stack walker)去拿到堆棧上值類型的大小和堆棧根。這裡我們來翻譯BotR里一篇專門介紹Stackwalking的文章,希望能加深理解。 順便說一句,StackWalker在中文里似乎還沒有統一的翻譯,J ...
  • 使用過 nginx 的小伙伴應該都知道,這個中間件是可以設置跨域的,作為今天的主角,同樣的 反向代理中間件的 YARP 毫無意外也支持了跨域請求設置。 有些小伙伴可能會問了,怎樣才算是跨域呢? 在 HTML 中,一些標簽,例如 img、a 等,還有我們非常熟悉的 Ajax,都是可以指向非本站的資源的 ...
  • 什麼是Git Git 是一個開源的分散式版本控制系統,用於敏捷高效地處理任何或小或大的項目。 Git 是 Linus Torvalds 為了幫助管理 Linux 內核開發而開發的一個開放源碼的版本控制軟體。 Git 與常用的版本控制工具 CVS, Subversion 等不同,它採用了分散式版本庫的 ...
  • 首先CR3是什麼,CR3是一個寄存器,該寄存器內保存有頁目錄表物理地址(PDBR地址),其實CR3內部存放的就是頁目錄表的記憶體基地址,運用CR3切換可實現對特定進程記憶體地址的強制讀寫操作,此類讀寫屬於有痕讀寫,多數驅動保護都會將這個地址改為無效,此時CR3讀寫就失效了,當然如果能找到CR3的正確地址... ...
  • 說明 onlyoffice為一款開源的office線上編輯組件,提供word/excel/ppt編輯保存操作 以下操作均基於centos8系統,officeonly鏡像版本7.1.2.23 鏡像下載地址:https://yunpan.360.cn/surl_y87CKKcPdY4 (提取碼:1f92 ...
  • 二叉樹查找指定的節點 前序查找的思路 1.先判斷當前節點的no是否等於要查找的 2.如果是相等,則返回當前節點 3.如果不等,則判斷當前節點的左子節點是否為空,如果不為空,則遞歸前序查找 4.如果左遞歸前序查找,找到節點,則返回,否繼續判斷,當前的節點的右子節點是否為空,如果不為空,則繼續向右遞歸前 ...
  • ##Invalid bound statement (not found)出現原因和解決方法 ###前言: 想必各位小伙伴在碼路上經常會碰到奇奇怪怪的事情,比如出現Invalid bound statement (not found),那今天我就來分析以下出現此問題的原因。 其實出現這個問題實質就是 ...
  • ###一、背景知識 爬蟲的本質就是一個socket客戶端與服務端的通信過程,如果我們有多個url待爬取,只用一個線程且採用串列的方式執行,那隻能等待爬取一個結束後才能繼續下一個,效率會非常低。 需要強調的是:對於單線程下串列N個任務,並不完全等同於低效,如果這N個任務都是純計算的任務,那麼該線程對c ...