Django查詢優(yōu)化及ajax編碼格式原理解析
orm查詢優(yōu)化
1)only與refer
only方法返回的是一個(gè)queryset對(duì)象,本質(zhì)就是列表套數(shù)據(jù)對(duì)象
該對(duì)象內(nèi)只含有only括號(hào)所指定的屬性(其他屬性也可以獲取,但是需要重新走數(shù)據(jù)庫(kù)查詢)
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)只能放外鍵字段,并且外鍵字段的類型只能是一對(duì)一或一對(duì)多,內(nèi)部是聯(lián)表操作,會(huì)將外鍵關(guān)聯(lián)的表與當(dāng)前表直接拼接起來(lái),然后再執(zhí)行查詢操作,返回的結(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)部是子查詢,返回的結(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í)主要耗在查詢次數(shù);
choices字段
用在一些字段數(shù)據(jù)是可以明確列出所有的可能的;比如:性別,工作經(jīng)驗(yàn),學(xué)歷,婚否,客戶來(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)求方式,小寫
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)解析并將文件類型的數(shù)據(jù)解析封裝到request.FILES中
application/json
ajax可以發(fā)送json格式的數(shù)據(jù),form表單不支持
#注意:數(shù)據(jù)類型和編碼格式要保證一致性
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的使用及避開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)文章
win32com操作word之Application&Documents接口學(xué)習(xí)
這篇文章主要為大家介紹了win32com操作word之Application&Documents接口學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01
Python爬蟲獲取數(shù)據(jù)保存到數(shù)據(jù)庫(kù)中的超詳細(xì)教程(一看就會(huì))
使用爬蟲爬數(shù)據(jù),總要涉及到數(shù)據(jù)持久化,也就是數(shù)據(jù)存儲(chǔ)的問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于Python爬蟲獲取數(shù)據(jù)保存到數(shù)據(jù)庫(kù)中的超詳細(xì)教程,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
基于Python?OpenCV和?dlib實(shí)現(xiàn)眨眼檢測(cè)
這篇文章主要介紹了基于Python?OPenCV及dlib實(shí)現(xiàn)檢測(cè)視頻流中的眨眼次數(shù)。文中的代碼對(duì)我們的學(xué)習(xí)和工作有一定價(jià)值,感興趣的同學(xué)可以參考一下2021-12-12
Python PyQt5干貨滿滿小項(xiàng)目輕松實(shí)現(xiàn)高效摳圖去背景
PyQt5以一套Python模塊的形式來(lái)實(shí)現(xiàn)功能。它包含了超過(guò)620個(gè)類,600個(gè)方法和函數(shù)。本篇文章手把手帶你用PyQt5輕松實(shí)現(xiàn)圖片扣除背景,大家可以在過(guò)程中查缺補(bǔ)漏,提升水平2021-11-11
關(guān)于python中.xpath的使用問(wèn)題
根據(jù)xpath定位到了tr,注意瀏覽器自動(dòng)生成了tbody,在python中要把自動(dòng)生成的tbody層級(jí)去掉,這樣要怎么操作呢?下面通過(guò)代碼給大家介紹下python中.xpath的使用問(wèn)題,感興趣的朋友一起看看吧2021-11-11
使用Python實(shí)現(xiàn)將Excel表格插入到Word文檔中
在日常辦公場(chǎng)景中,通過(guò)Python腳本自動(dòng)化整合Excel數(shù)據(jù)與Word文檔,能夠?qū)崿F(xiàn)表格的智能遷移,滿足不同場(chǎng)景下數(shù)據(jù)呈現(xiàn)的專業(yè)性要求,下面小編就來(lái)為大家介紹一下具體實(shí)現(xiàn)的三種方法吧2025-03-03

