Django查詢(xún)優(yōu)化及ajax編碼格式原理解析
orm查詢(xún)優(yōu)化
1)only與refer
only方法返回的是一個(gè)queryset對(duì)象,本質(zhì)就是列表套數(shù)據(jù)對(duì)象
該對(duì)象內(nèi)只含有only括號(hào)所指定的屬性(其他屬性也可以獲取,但是需要重新走數(shù)據(jù)庫(kù)查詢(xún))
defer與only互為反關(guān)系,返回的是一個(gè)queryset對(duì)象,本質(zhì)就是列表套數(shù)據(jù)對(duì)象;該對(duì)象只含有除了defer括號(hào)內(nèi)所指定的屬性(括號(hào)內(nèi)的屬性也可以獲取但是需要重新走數(shù)據(jù)庫(kù))
2)select_related與prefetch_related
select_related括號(hào)內(nèi)只能放外鍵字段,并且外鍵字段的類(lèi)型只能是一對(duì)一或一對(duì)多,內(nèi)部是聯(lián)表操作,會(huì)將外鍵關(guān)聯(lián)的表與當(dāng)前表直接拼接起來(lái),然后再執(zhí)行查詢(xún)操作,返回的結(jié)果也是一個(gè)queryset,列表套數(shù)據(jù)對(duì)象,該數(shù)據(jù)對(duì)象獲取當(dāng)前表中的數(shù)據(jù)或者關(guān)聯(lián)表中的數(shù)據(jù),都不會(huì)再走數(shù)據(jù)庫(kù);
prefetch_related 括號(hào)內(nèi)外鍵字段全部支持,內(nèi)部是子查詢(xún),返回的結(jié)果也是一個(gè)queryset對(duì)象,列表套數(shù)據(jù)對(duì)象,該數(shù)據(jù)對(duì)象獲取當(dāng)前表中的數(shù)據(jù)或者關(guān)聯(lián)表中的數(shù)據(jù),都不會(huì)再走數(shù)據(jù)庫(kù);
第一個(gè)方法耗時(shí)主要耗在聯(lián)表操作,第二個(gè)方法耗時(shí)主要耗在查詢(xún)次數(shù);
choices字段
用在一些字段數(shù)據(jù)是可以明確列出所有的可能的;比如:性別,工作經(jīng)驗(yàn),學(xué)歷,婚否,客戶(hù)來(lái)源等;
1.先定義好對(duì)應(yīng)關(guān)系;2.在通過(guò)字段的choices參數(shù)來(lái)指定關(guān)系。
gender_choices = (
(1,'male'),
(2,'female'),
(3,'others'),
)
gender = models.IntegerField(choices = gender_choices)
如果數(shù)據(jù)在你事先定義好的范圍內(nèi),可以通過(guò)get_字段名_display()拿到對(duì)應(yīng)的解釋信息。
ajax
1.異步提交 2.局部刷新
ajax基本語(yǔ)法結(jié)構(gòu)
現(xiàn)用的是基于JQuery封裝好的ajax,所以用ajax的時(shí)候,先導(dǎo)入jQuery;
$.ajax({ url:'', # 后端的地址,特性跟action一直,三種情況 type:'post', # 請(qǐng)求方式,小寫(xiě) data:{'username':'zhang',password:'123'}, # 提交的數(shù)據(jù) success:function(data){ # data異步提交的結(jié)果 # 回調(diào)機(jī)制返回的結(jié)果 # window.location.href = url } }) #基于ajax做數(shù)據(jù)交互,后端無(wú)論返回什么結(jié)果都會(huì)被回調(diào)函數(shù)捕獲,不會(huì)再影響整個(gè)頁(yè)面
前后端數(shù)據(jù)傳輸編碼格式
urlencoded
數(shù)據(jù)格式username=zhang&password=123
django針對(duì)符合urlencoded編碼格式的數(shù)據(jù),會(huì)自動(dòng)解析并放到request.POST中;
formdata
form表單發(fā)送文件必須要指定的編碼格式
該編碼格式既可以發(fā)文件也可以發(fā)普通的鍵值對(duì)
django后端自動(dòng)識(shí)別,將內(nèi)部符合urlencoded編碼格式的數(shù)據(jù),自動(dòng)解析并將文件類(lèi)型的數(shù)據(jù)解析封裝到request.FILES中
application/json
ajax可以發(fā)送json格式的數(shù)據(jù),form表單不支持
#注意:數(shù)據(jù)類(lèi)型和編碼格式要保證一致性
ajax如何發(fā)送json格式的數(shù)據(jù)
需要在前端新增一個(gè)參數(shù)
contentType:'application/json'
需要將數(shù)據(jù)序列化成json格式的字符串
JSON.stringfy({'username':'zhang','password':'123'})
注意:django后端針對(duì)json格式的數(shù)據(jù),不會(huì)做任何處理,原封不動(dòng)的在放request.body內(nèi)
ajax發(fā)送文件(不單單可以發(fā)送文件,也可以發(fā)送普通鍵值對(duì))
建議借助原生js的內(nèi)置對(duì)象幫你做數(shù)據(jù)攜帶
1).先生成一個(gè)內(nèi)置對(duì)象
var MyFormData = new FormData();
2).然后朝該對(duì)象內(nèi)添加數(shù)據(jù)(普通鍵值對(duì)和文件均可)
普通鍵值對(duì)
MyFormData.append('name','value')
MyFormData.append('name1','value1')
MyFormData.append('name2','value2')
文件數(shù)據(jù)
如何獲取input文件標(biāo)簽內(nèi)文件數(shù)據(jù)
var MyFileobj = $("input[type='file']")[0].files[0];
3.需要額外指定兩個(gè)參數(shù)
contentType:false, # 不指定任何編碼,對(duì)象自帶編碼 django能夠識(shí)別;
processData:false, # 瀏覽器不需要對(duì)數(shù)據(jù)進(jìn)行任何處理
django能夠識(shí)別對(duì)象中的普通的鍵值對(duì)和文件對(duì)象,然后分別放到不同的方法POST和FILES中;
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Django如何與Ajax交互
- Django與AJAX實(shí)現(xiàn)網(wǎng)頁(yè)動(dòng)態(tài)數(shù)據(jù)顯示的示例代碼
- 使用AJAX和Django獲取數(shù)據(jù)的方法實(shí)例
- 淺析Django 接收所有文件,前端展示文件(包括視頻,文件,圖片)ajax請(qǐng)求
- django ajax發(fā)送post請(qǐng)求的兩種方法
- django框架中ajax的使用及避開(kāi)CSRF 驗(yàn)證的方式詳解
- Django中ajax發(fā)送post請(qǐng)求 報(bào)403錯(cuò)誤CSRF驗(yàn)證失敗解決方案
- Django結(jié)合ajax進(jìn)行頁(yè)面實(shí)時(shí)更新的例子
- Django 通過(guò)JS實(shí)現(xiàn)ajax過(guò)程詳解
- Django利用AJAX技術(shù)實(shí)現(xiàn)博文實(shí)時(shí)搜索
相關(guān)文章
基于python select.select模塊通信的實(shí)例講解
下面小編就為大家?guī)?lái)一篇基于python select.select模塊通信的實(shí)例講解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09Python設(shè)計(jì)模式之抽象工廠(chǎng)模式原理與用法詳解
這篇文章主要介紹了Python設(shè)計(jì)模式之抽象工廠(chǎng)模式,簡(jiǎn)單講述了抽象工廠(chǎng)模式的概念、原理并結(jié)合實(shí)例形式分析了Python實(shí)現(xiàn)與使用抽象工廠(chǎng)模式的相關(guān)操作技巧,需要的朋友可以參考下2019-01-01何用Python實(shí)現(xiàn)一個(gè) “系統(tǒng)聲音” 的實(shí)時(shí)律動(dòng)掛件
這篇文章將給大家介紹了如何用 Python 實(shí)現(xiàn)一個(gè) “系統(tǒng)聲音” 的實(shí)時(shí)律動(dòng)掛件,采集后直接實(shí)時(shí)地在電腦上繪制波形動(dòng)畫(huà),主要是用來(lái)作為 FL Studio 播放時(shí)的一個(gè)桌面小掛件,文中有相關(guān)的代碼示例供大家參考,需要的朋友可以參考下2024-01-01Python文件操作及內(nèi)置函數(shù)flush原理解析
這篇文章主要介紹了Python文件操作及內(nèi)置函數(shù)flush原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10Python實(shí)例方法、類(lèi)方法、靜態(tài)方法區(qū)別詳解
這篇文章主要介紹了Python實(shí)例方法、類(lèi)方法、靜態(tài)方法區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09安裝Keras,tensorflow,并實(shí)現(xiàn)將虛擬環(huán)境添加到j(luò)upyter?notebook
這篇文章主要介紹了安裝Keras,tensorflow,并實(shí)現(xiàn)將虛擬環(huán)境添加到j(luò)upyter?notebook,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03