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
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...