溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Django查詢優(yōu)化的示例分析

發(fā)布時(shí)間:2021-05-12 11:05:17 來(lái)源:億速云 閱讀:149 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家分享的是有關(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ò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI