您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)Django查詢優(yōu)化的示例分析的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
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)求方式,小寫(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)解析并將文件類型的數(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中;
感謝各位的閱讀!關(guān)于“Django查詢優(yōu)化的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。