Django框架(七):模型(三) 關聯、模型類的屬性

来源:https://www.cnblogs.com/liuhui0308/archive/2020/01/20/12219029.html
-Advertisement-
Play Games

1. 關聯 1.1 模型類關係 關係型資料庫的關係包括三種類型: ForeignKey:一對多,將欄位定義在多的一端中。 ManyToManyField:多對多,將欄位定義在任意一端中。 OneToOneField:一對一,將欄位定義在任意一端中。 1.1.1 一對多關係 #定義圖書模型類BookI ...


1. 關聯

1.1 模型類關係

關係型資料庫的關係包括三種類型:

  • ForeignKey:一對多,將欄位定義在多的一端中。
  • ManyToManyField:多對多,將欄位定義在任意一端中。
  • OneToOneField:一對一,將欄位定義在任意一端中。

1.1.1 一對多關係

#定義圖書模型類BookInfo
class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)#圖書名稱
    bpub_date = models.DateField()#發佈日期
    bread = models.IntegerField(default=0)#閱讀量
    bcomment = models.IntegerField(default=0)#評論量
    isDelete = models.BooleanField(default=False)#邏輯刪除

#定義角色模型類RoleInfo
class RoleInfo(models.Model):
    rname = models.CharField(max_length=20)#角色姓名
    rgender = models.BooleanField(default=True)#角色性別
    isDelete = models.BooleanField(default=False)#邏輯刪除
    rcomment = models.CharField(max_len角色與圖書表的關係為一對多,所以屬性定義在角色模型類中

1.1.2 多對多關係

我們下麵設計一個新聞類和新聞類型類,一個新聞類型下可以用很多條新聞,一條新聞也可能歸屬於多種新聞類型。

class TypeInfo(models.Model):
  tname = models.CharField(max_length=20) #新聞類別

class NewsInfo(models.Model):
  ntitle = models.CharField(max_length=60) #新聞標題
  ncontent = models.TextField() #新聞內容
  npub_date = models.DateTimeField(auto_now_add=True) #新聞發佈時間
  ntype = models.ManyToManyField('TypeInfo') #通過ManyToManyField建立TypeInfo類和NewsInfo類之間多對多的關係

1.2 關聯查詢

Django中也能實現類似於join查詢。

1.2.1 通過對象執行關聯查詢

在定義模型類時,可以指定三種關聯關係,最常用的是一對多關係,例如“圖書-角色”就是一對多關係。

#一對應的模型類對象.多對應的模型類名小寫_set

b = BookInfo.objects.get(id=1)
b.heroinfo_set.all()

由多到一的訪問語法:

#多對應的模型類對象.多對應的模型類中的關係類屬性名

r = RoleInfo.objects.get(id=1)
r.rbook

訪問一對應的模型類關聯對象的id語法:

#多對應的模型類對象.關聯類屬性_id

r = RoleInfo.objects.get(id=1)
r.book_id

例:查詢編號為1的圖書。

book=BookInfo.objects.get(pk=1)

例:獲得book圖書的所有角色。

book.roleinfo_set.all()

例:獲得編號為1的角色。

role=RoleInfo.objects.get(pk=1)

例:獲得role角色出自的圖書。

role.rbook

1.2.2 通過模型類執行關聯查詢

由多模型類條件查詢一模型類數據:

語法如下:

關聯模型類名小寫__屬性名__條件運算符=值

如果沒有"__運算符"部分,表示等於,結果和sql中的inner join相同。

例:查詢圖書,要求圖書中英雄的描述包含'韓'。

list = BookInfo.objects.filter(heroinfo__hcontent__contains='')

由一模型類條件查詢多模型類數據:

語法如下:

一模型類關聯屬性名__一模型類屬性名__條件運算符=值

例:查詢書名為“鬥羅大陸”的所有英雄。

list = HeroInfo.objects.filter(hbook__btitle='鬥羅大陸')

1.3 自關聯

對於地區信息、分類信息等數據,表結構非常類似,每個表的數據量十分有限,為了充分利用數據表的大量數據存儲功能,可以設計成一張表,內部的關係欄位指向本表的主鍵,這就是自關聯的表結構。

打開booktest/models.py文件,定義AreaInfo類。

關係屬性使用self指向本類,要求null和blank允許為空,因為一級數據是沒有父級的。

#定義地區模型類,存儲省、市、區縣信息
class AreaInfo(models.Model):
    atitle=models.CharField(max_length=30)#名稱
    aParent=models.ForeignKey('self',null=True,blank=True)#關係

遷移。

python manage.py makemigrations
python manage.py migrate

打開mysql命令行,導入數據。

INSERT INTO booktest_areainfo VALUES ('440000', '廣東省', NULL);
INSERT INTO booktest_areainfo VALUES ('440100', '廣州市', '440000');
INSERT INTO booktest_areainfo VALUES ('440103', '荔灣區', '440100');
INSERT INTO booktest_areainfo VALUES ('440104', '越秀區', '440100');
INSERT INTO booktest_areainfo VALUES ('440105', '海珠區', '440100');
INSERT INTO booktest_areainfo VALUES ('440106', '天河區', '440100');
INSERT INTO booktest_areainfo VALUES ('440111', '白雲區', '440100');
INSERT INTO booktest_areainfo VALUES ('440112', '黃埔區', '440100');
INSERT INTO booktest_areainfo VALUES ('440113', '番禺區', '440100');
INSERT INTO booktest_areainfo VALUES ('440114', '花都區', '440100');
INSERT INTO booktest_areainfo VALUES ('440115', '南沙區', '440100');
INSERT INTO booktest_areainfo VALUES ('440116', '蘿崗區', '440100');
INSERT INTO booktest_areainfo VALUES ('440183', '增城市', '440100');
INSERT INTO booktest_areainfo VALUES ('440184', '從化市', '440100');
INSERT INTO booktest_areainfo VALUES ('440200', '韶關市', '440000');
INSERT INTO booktest_areainfo VALUES ('440203', '武江區', '440200');
INSERT INTO booktest_areainfo VALUES ('440204', '湞江區', '440200');
INSERT INTO booktest_areainfo VALUES ('440205', '曲江區', '440200');
INSERT INTO booktest_areainfo VALUES ('440222', '始興縣', '440200');
INSERT INTO booktest_areainfo VALUES ('440224', '仁化縣', '440200');
INSERT INTO booktest_areainfo VALUES ('440229', '翁源縣', '440200');
INSERT INTO booktest_areainfo VALUES ('440232', '乳源瑤族自治縣', '440200');
INSERT INTO booktest_areainfo VALUES ('440233', '新豐縣', '440200');
INSERT INTO booktest_areainfo VALUES ('440281', '樂昌市', '440200');
INSERT INTO booktest_areainfo VALUES ('440282', '南雄市', '440200');
INSERT INTO booktest_areainfo VALUES ('440300', '深圳市', '440000');
INSERT INTO booktest_areainfo VALUES ('440303', '羅湖區', '440300');
INSERT INTO booktest_areainfo VALUES ('440304', '福田區', '440300');
INSERT INTO booktest_areainfo VALUES ('440305', '南山區', '440300');
INSERT INTO booktest_areainfo VALUES ('440306', '寶安區', '440300');
INSERT INTO booktest_areainfo VALUES ('440307', '龍崗區', '440300');
INSERT INTO booktest_areainfo VALUES ('440308', '鹽田區', '440300');
INSERT INTO booktest_areainfo VALUES ('440400', '珠海市', '440000');
INSERT INTO booktest_areainfo VALUES ('440402', '香洲區', '440400');
INSERT INTO booktest_areainfo VALUES ('440403', '斗門區', '440400');
INSERT INTO booktest_areainfo VALUES ('440404', '金灣區', '440400');
INSERT INTO booktest_areainfo VALUES ('440500', '汕頭市', '440000');
INSERT INTO booktest_areainfo VALUES ('440507', '龍湖區', '440500');
INSERT INTO booktest_areainfo VALUES ('440511', '金平區', '440500');
INSERT INTO booktest_areainfo VALUES ('440512', '濠江區', '440500');
INSERT INTO booktest_areainfo VALUES ('440513', '潮陽區', '440500');
INSERT INTO booktest_areainfo VALUES ('440514', '潮南區', '440500');
INSERT INTO booktest_areainfo VALUES ('440515', '澄海區', '440500');
INSERT INTO booktest_areainfo VALUES ('440523', '南澳縣', '440500');
INSERT INTO booktest_areainfo VALUES ('440600', '佛山市', '440000');
INSERT INTO booktest_areainfo VALUES ('440604', '禪城區', '440600');
INSERT INTO booktest_areainfo VALUES ('440605', '南海區', '440600');
INSERT INTO booktest_areainfo VALUES ('440606', '順德區', '440600');
INSERT INTO booktest_areainfo VALUES ('440607', '三水區', '440600');
INSERT INTO booktest_areainfo VALUES ('440608', '高明區', '440600');
INSERT INTO booktest_areainfo VALUES ('440700', '江門市', '440000');
INSERT INTO booktest_areainfo VALUES ('440703', '蓬江區', '440700');
INSERT INTO booktest_areainfo VALUES ('440704', '江海區', '440700');
INSERT INTO booktest_areainfo VALUES ('440705', '新會區', '440700');
INSERT INTO booktest_areainfo VALUES ('440781', '台山市', '440700');
INSERT INTO booktest_areainfo VALUES ('440783', '開平市', '440700');
INSERT INTO booktest_areainfo VALUES ('440784', '鶴山市', '440700');
INSERT INTO booktest_areainfo VALUES ('440785', '恩平市', '440700');
INSERT INTO booktest_areainfo VALUES ('440800', '湛江市', '440000');
INSERT INTO booktest_areainfo VALUES ('440802', '赤坎區', '440800');
INSERT INTO booktest_areainfo VALUES ('440803', '霞山區', '440800');
INSERT INTO booktest_areainfo VALUES ('440804', '坡頭區', '440800');
INSERT INTO booktest_areainfo VALUES ('440811', '麻章區', '440800');
INSERT INTO booktest_areainfo VALUES ('440823', '遂溪縣', '440800');
INSERT INTO booktest_areainfo VALUES ('440825', '徐聞縣', '440800');
INSERT INTO booktest_areainfo VALUES ('440881', '廉江市', '440800');
INSERT INTO booktest_areainfo VALUES ('440882', '雷州市', '440800');
INSERT INTO booktest_areainfo VALUES ('440883', '吳川市', '440800');
INSERT INTO booktest_areainfo VALUES ('440900', '茂名市', '440000');
INSERT INTO booktest_areainfo VALUES ('440902', '茂南區', '440900');
INSERT INTO booktest_areainfo VALUES ('440903', '茂港區', '440900');
INSERT INTO booktest_areainfo VALUES ('440923', '電白縣', '440900');
INSERT INTO booktest_areainfo VALUES ('440981', '高州市', '440900');
INSERT INTO booktest_areainfo VALUES ('440982', '化州市', '440900');
INSERT INTO booktest_areainfo VALUES ('440983', '信宜市', '440900');
INSERT INTO booktest_areainfo VALUES ('441200', '肇慶市', '440000');
INSERT INTO booktest_areainfo VALUES ('441202', '端州區', '441200');
INSERT INTO booktest_areainfo VALUES ('441203', '鼎湖區', '441200');
INSERT INTO booktest_areainfo VALUES ('441223', '廣寧縣', '441200');
INSERT INTO booktest_areainfo VALUES ('441224', '懷集縣', '441200');
INSERT INTO booktest_areainfo VALUES ('441225', '封開縣', '441200');
INSERT INTO booktest_areainfo VALUES ('441226', '德慶縣', '441200');
INSERT INTO booktest_areainfo VALUES ('441283', '高要市', '441200');
INSERT INTO booktest_areainfo VALUES ('441284', '四會市', '441200');
INSERT INTO booktest_areainfo VALUES ('441300', '惠州市', '440000');
INSERT INTO booktest_areainfo VALUES ('441302', '惠城區', '441300');
INSERT INTO booktest_areainfo VALUES ('441303', '惠陽區', '441300');
INSERT INTO booktest_areainfo VALUES ('441322', '博羅縣', '441300');
INSERT INTO booktest_areainfo VALUES ('441323', '惠東縣', '441300');
INSERT INTO booktest_areainfo VALUES ('441324', '龍門縣', '441300');
INSERT INTO booktest_areainfo VALUES ('441400', '梅州市', '440000');
INSERT INTO booktest_areainfo VALUES ('441402', '梅江區', '441400');
INSERT INTO booktest_areainfo VALUES ('441421', '梅縣', '441400');
INSERT INTO booktest_areainfo VALUES ('441422', '大埔縣', '441400');
INSERT INTO booktest_areainfo VALUES ('441423', '豐順縣', '441400');
INSERT INTO booktest_areainfo VALUES ('441424', '五華縣', '441400');
INSERT INTO booktest_areainfo VALUES ('441426', '平遠縣', '441400');
INSERT INTO booktest_areainfo VALUES ('441427', '蕉嶺縣', '441400');
INSERT INTO booktest_areainfo VALUES ('441481', '興寧市', '441400');
INSERT INTO booktest_areainfo VALUES ('441500', '汕尾市', '440000');
INSERT INTO booktest_areainfo VALUES ('441502', '城區', '441500');
INSERT INTO booktest_areainfo VALUES ('441521', '海豐縣', '441500');
INSERT INTO booktest_areainfo VALUES ('441523', '陸河縣', '441500');
INSERT INTO booktest_areainfo VALUES ('441581', '陸豐市', '441500');

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

-Advertisement-
Play Games
更多相關文章
  • Y 維度就是從業務 HTTP 請求的橫向處理流程來看,HTTP 請求會穿越網路、電腦、應用容器(Tomcat)、Spring、ORM(Hibernate)、資料庫等節點,在這個流程中每個節點都有許多可以可優化的地方,今天老兵哥將介紹通過優化開發框架 Spring 來優化系統性能的方法。 ...
  • GoF: 必背 24種設計模式 : 設計原則: 設計模式(總綱) 創建型(6): 單例模式 簡單工廠模式 工廠方法模式 抽象工廠模式 建造者模式 原型模式 結構型(7 ,2個器,5個兩字的): 代理模式 適配器模式 裝飾器模式 橋接模式 組合模式 享元模式 外觀模式 行為型(11): 觀察者模式 模 ...
  • 恢復內容開始 RabbitMQ基本概念: Producer:生產者(消息的提供者) Consumer:消費者(消息的使用者) Message:消息(程式之間消息的通信) Queue:隊列(消息存放的容器,消息先進先出) Vhost:虛擬主機(相當於MQ的資料庫,用於存儲隊列) 創建虛擬主機: 生產者 ...
  • 一、error 1.URLError產生的原因:(1)沒有網路;(2)伺服器連接失敗;(3)不知道指定伺服器;(4)是OSError的子類 from urllib import request,error ​ if __name__ == "__main__": url = "http://www. ...
  • 題目一 計算十進位數字在二進位表示 1 的個數 舉個例子: 十進位數字為 1 時,它的二進位表示是 001,二進位表示 1 的個數為 1; 十進位數字為 2 時,它的二進位表示是 010,二進位表示 1 的個數為 1; 十進位數字為 3 時,它的二進位表示是 011,二進位表示 1 的個數為 2; ...
  • 實現的關於線上考試的功能有:用戶前臺:用戶註冊登錄、查看考試信息、進行考試、查看考試成績、查看歷史考試記錄、回顧已考試卷、修改密碼、修改個人信息等,後臺管理功能(腳手架功能不在這裡列出),科目專業管理、考生管理、試題管理、考試管理、試卷管理、答題詳情管理、考試成績圖表統計等,其中試題可以支持批量ex ...
  • 基於JDK1.7 HashMap源碼分析 概述 HashMap是存放鍵值對的集合,數據結構如下: 1. table被稱為桶,大小(capacity)始終為2的冪,當發生擴容時,map容量擴大為兩倍 2. HashMap採用拉鏈法解決Hash衝突,發生衝突時,新元素採用頭插法插入到對應桶的鏈表中 Ha ...
  • 實現的關於線上考試的功能有:用戶前臺:用戶註冊登錄、查看考試信息、進行考試、查看考試成績、查看歷史考試記錄、回顧已考試卷、修改密碼、修改個人信息等,後臺管理功能(腳手架功能不在這裡列出),科目專業管理、考生管理、試題管理、考試管理、試卷管理、答題詳情管理、考試成績圖表統計等,其中試題可以支持批量ex ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...