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
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...