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
  • 一:背景 1.講故事 在分析的眾多dump中,經常會遇到各種奇葩的問題,僅通過dump這種快照形式還是有很多問題搞不定,而通過 perfview 這種粒度又太粗,很難找到問題之所在,真的很頭疼,比如本篇的 短命線程 問題,參考圖如下: 我們在 t2 時刻抓取的dump對查看 短命線程 毫無幫助,我根 ...
  • 在日常後端Api開發中,我們跟前端的溝通中,通常需要協商好入參的數據類型,和參數是通過什麼方式存在於請求中的,是表單(form)、請求體(body)、地址欄參數(query)、還是說通過請求頭(header)。 當協商好後,我們的介面又需要怎麼去接收這些數據呢?很多小伙伴可能上手就是直接寫一個實體, ...
  • 許多情況下我們需要用到攝像頭獲取圖像,進而處理圖像,這篇博文介紹利用pyqt5、OpenCV實現用電腦上連接的攝像頭拍照並保存照片。為了使用和後續開發方便,這裡利用pyqt5設計了個相機界面,後面將介紹如何實現,要點包括界面設計、邏輯實現及完整代碼。 ...
  • 思路分析 註冊頁面需要對用戶提交的數據進行校驗,並且需要對用戶輸入錯誤的地方進行提示! 所有我們需要使用forms組件搭建註冊頁面! 平時我們書寫form是組件的時候是在views.py裡面書寫的, 但是為了接耦合,我們需要將forms組件都單獨寫在一個地方,需要用的時候導入就行! 例如,在項目文件 ...
  • 思路分析 登錄頁面,我們還是採用ajax的方式提交用戶數據 唯一需要學習的是如何製作圖片驗證碼! 具體的登錄頁面效果圖如下: 如何製作圖片驗證碼 推導步驟1:在img標簽的src屬性里放上驗證碼的請求路徑 補充1.img的src屬性: 1.圖片路徑 2.url 3.圖片的二進位數據 補充2:字體樣式 ...
  • 哈嘍,兄弟們! 最近有許多小伙伴都在吐槽打工好難。 每天都是執行許多重覆的任務 例如閱讀新聞、發郵件、查看天氣、打開書簽、清理文件夾等等, 使用自動化腳本,就無需手動一次又一次地完成這些任務, 非常方便啊有木有?! 而在某種程度上,Python 就是自動化的代名詞。 今天就來和大家一起學習一下, 用 ...
  • 作者:IT王小二 博客:https://itwxe.com 前面小二介紹過使用Typora+PicGo+LskyPro打造舒適寫作環境,那時候需要使用水印功能,但是小二在升級LskyPro2.x版本發現有很多不如人意的東西,遂棄用LskyPro使用MinIO結合代碼實現自己需要的圖床功能,也適合以後 ...
  • OpenAI Gym是一款用於研發和比較強化學習演算法的工具包,本文主要介紹Gym模擬環境的功能和工具包的使用方法,並詳細介紹其中的經典控制問題中的倒立擺(CartPole-v0/1)問題。最後針對倒立擺問題如何建立控制模型並採用爬山演算法優化進行了介紹,並給出了相應的完整python代碼示例和解釋。要... ...
  • python爬蟲瀏覽器偽裝 #導入urllib.request模塊 import urllib.request #設置請求頭 headers=("User-Agent","Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, l ...
  • 前端代碼搭建 主要利用的是bootstrap3中js插件里的模態框版塊 <li><a href="" data-toggle="modal" data-target=".bs-example-modal-lg">修改密碼</a></li> <div class="modal fade bs-exam ...