版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、Django框架講師:塔卡 時(shí)間:2018年7月免責(zé)聲明:如果本課程內(nèi)有任何內(nèi)容侵害了您的權(quán)益,請(qǐng)您及時(shí)聯(lián)系我們 潭州教育全球教學(xué)服務(wù)中心熱線: 知識(shí)回顧:LOREM01020304表關(guān)系的實(shí)現(xiàn)Field的常用參數(shù)常用的模型字段類型常用的查詢01關(guān)系表的數(shù)據(jù)操作03多表查詢02表關(guān)聯(lián)對(duì)象的訪問Django模型基礎(chǔ)第三節(jié)LOREM關(guān)系表中的數(shù)據(jù)操作:學(xué)院信息表學(xué)生信息表d_idd_names_ids_iddepartment_id外鍵關(guān)聯(lián)LOREM進(jìn)入項(xiàng)目目錄的IDLE:為了能方便學(xué)習(xí),我們進(jìn)入項(xiàng)目的idle中去執(zhí)行我們的操作,通過python manage.py shell 就能進(jìn)入當(dāng)前目錄下
2、的IDLE1.進(jìn)入IDLE2.查看當(dāng)前的目錄路徑3.導(dǎo)入我們項(xiàng)目中的模型類關(guān)系表的數(shù)據(jù)操作:LOREM1.先往數(shù)據(jù)表department中添加數(shù)據(jù).2.查看數(shù)據(jù)表student的表結(jié)構(gòu).department_id字段就是外鍵關(guān)聯(lián)的department表中的d_id字段一對(duì)多表關(guān)系數(shù)據(jù)的添加:LOREM3.往數(shù)據(jù)表student中添加數(shù)據(jù)的第一種方式4.往數(shù)據(jù)表student中添加數(shù)據(jù)的第二種方式1.第一種方式就是跟之前的一樣,用傳參的方法添加,需要注意的是外鍵的值必須是關(guān)聯(lián)表中已經(jīng)存在的值.2.第二種方式是用的屬性賦值的方式,因?yàn)槲覀冊(cè)谀P皖愑卸x了一個(gè)department的屬性,而這個(gè)屬性的
3、對(duì)象的類型必須是department表的類實(shí)例對(duì)象表關(guān)聯(lián)對(duì)象的訪問:LOREMStudentDeparmentStudent的模型類中我們有定義department的屬性,所以當(dāng)我們?nèi)ピL問的時(shí)候,可以直接通過student.department的形式去找到某個(gè)學(xué)生的所屬學(xué)院是哪個(gè).那么如果我們也希望在在訪問某個(gè)學(xué)院的實(shí)現(xiàn)對(duì)象的學(xué)生的時(shí)候改怎么訪問呢?表關(guān)聯(lián)對(duì)象的訪問:LOREM如果模型I有一個(gè)ForeignKey,那么該ForeignKey 所指的模型II實(shí)例可以通過一個(gè)管理器回前面有ForeignKey的模型I的所有實(shí)例。默認(rèn)情況下,這個(gè)管理器的名字為foo_set,其中foo 是源模型的小
4、寫名稱。表關(guān)聯(lián)對(duì)象的訪問:LOREM可以在定義時(shí)設(shè)置related_name 參數(shù)來覆蓋foo_set 的名稱.LOREM表關(guān)聯(lián)對(duì)象的訪問:添加了related_name的參數(shù)后,重新打開一個(gè)IDLE,訪問時(shí)就能直接用設(shè)置的參數(shù)作為屬性了.LOREM表關(guān)聯(lián)對(duì)象的訪問:先獲取到三個(gè)表中實(shí)例對(duì)象是個(gè)實(shí)例對(duì)象這三個(gè)返回的是管理器這里顯示沒這個(gè)屬性是沒設(shè)置多對(duì)多關(guān)系中related_name處理關(guān)聯(lián)對(duì)象的一些方法:LOREMadd(obj1, obj2, .) 添加的已經(jīng)存在數(shù)據(jù)庫(kù)的數(shù)據(jù)添加一指定的模型對(duì)象到關(guān)聯(lián)的對(duì)象集中。1.d1.student的管理器有add的方法.2.例子中的s2能添加成功是因
5、為設(shè)置了student表中department字段允許為空了.LOREM處理關(guān)聯(lián)對(duì)象的一些方法:create(*kwargs) 添加不存在的數(shù)據(jù) ,將數(shù)據(jù)直接存入數(shù)據(jù)庫(kù)創(chuàng)建一個(gè)新的對(duì)象,將它保存并放在關(guān)聯(lián)的對(duì)象集返回新創(chuàng)建的對(duì)象。這三個(gè)返回的是管理器這里通過管理器就能使用create的方法去添加數(shù)據(jù)LOREM處理關(guān)聯(lián)對(duì)象的一些方法:remove(obj1, obj2, .)從關(guān)聯(lián)的對(duì)象集中刪除指定的模型對(duì)象。刪除的是關(guān)系表中的數(shù)據(jù)因?yàn)槲覀冇行薷膕tudent表中的department_id字段允許為空,所以當(dāng)刪除的時(shí)候這個(gè)字段值為NULL.LOREM處理關(guān)聯(lián)對(duì)象的一些方法:clear() 從關(guān)
6、聯(lián)的對(duì)象集中刪除所有的對(duì)象注意對(duì)于所有類型的關(guān)聯(lián)字段,add()、create()、remove()和clear()都會(huì)馬上更新數(shù)據(jù)庫(kù)。換句話說,在關(guān)聯(lián)的任何一端,都不需要再調(diào)用save()方法。LOREM多表查詢-跨關(guān)聯(lián)關(guān)系的查詢:Django 提供一種強(qiáng)大而又直觀的方式來“處理”查詢中的關(guān)聯(lián)關(guān)系,它在后臺(tái)自動(dòng)幫你處理JOIN。 若要跨越關(guān)聯(lián)關(guān)系,只需使用關(guān)聯(lián)的模型字段的名稱,并使用雙下劃線分隔,直至你想要的字段:# 查詢學(xué)院名字為計(jì)算機(jī)學(xué)院的學(xué)生的信息 Student.objects.filter(department_d_name=計(jì)算機(jī)學(xué)院)它還可以反向工作。若要引用一個(gè)“反向”的關(guān)系
7、,只需要使用該模型的小寫的名稱。#查詢學(xué)生名字中包含 小 的學(xué)生的學(xué)院信息Department.objects.filter(student_s_name_contains=小)LOREM多表查詢-跨關(guān)聯(lián)關(guān)系的查詢:# 查詢學(xué)號(hào)為1的學(xué)生所有的課程Course.objects.filter(student_s_id=1)# 查詢報(bào)了課程1的所有的學(xué)生Student.objects.filter(course_c_id=1)# 查詢報(bào)了python課程的的學(xué)生的所屬學(xué)院的信息Department.objects.filter(student_course_c_name=python)總結(jié)管理器進(jìn)入IDLErelated_name完多表查詢add,create,r
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025版食堂原材料供應(yīng)與質(zhì)量保證合同3篇
- 二零二五年度個(gè)人住房貸款擔(dān)保合同范本3篇
- 家居建材行業(yè)廣告總結(jié)
- 二零二五年度戶外運(yùn)動(dòng)裝備售后維修服務(wù)協(xié)議3篇
- 二零二五版?zhèn)€人住宅二手房居住權(quán)買賣與室內(nèi)空氣質(zhì)量檢測(cè)合同4篇
- 2025年度個(gè)人二手房交易貸款服務(wù)協(xié)議2篇
- 2025版租賃合同提前終止及解除后物業(yè)管理責(zé)任及費(fèi)用承擔(dān)協(xié)議3篇
- 二零二五年字畫藝術(shù)品私人定制合同范本3篇
- 二零二五年度公共安全系統(tǒng)購(gòu)銷協(xié)議3篇
- 食品配送衛(wèi)生安全規(guī)范
- 【可行性報(bào)告】2023年電動(dòng)自行車項(xiàng)目可行性研究分析報(bào)告
- 五月天歌詞全集
- 商品退換貨申請(qǐng)表模板
- 實(shí)習(xí)單位鑒定表(模板)
- 六西格瑪(6Sigma)詳解及實(shí)際案例分析
- 機(jī)械制造技術(shù)-成都工業(yè)學(xué)院中國(guó)大學(xué)mooc課后章節(jié)答案期末考試題庫(kù)2023年
- 數(shù)字媒體應(yīng)用技術(shù)專業(yè)調(diào)研方案
- 2023年常州市新課結(jié)束考試九年級(jí)數(shù)學(xué)試卷(含答案)
- 正常分娩 分娩機(jī)制 助產(chǎn)學(xué)課件
- 廣東縣級(jí)農(nóng)商銀行聯(lián)社高管候選人公開競(jìng)聘筆試有關(guān)事項(xiàng)上岸提分題庫(kù)3套【500題帶答案含詳解】
- 中國(guó)成人住院患者高血糖管理目標(biāo)專家共識(shí)課件
評(píng)論
0/150
提交評(píng)論