這篇文章給大家分享的是有關Django查詢優(yōu)化的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
orm查詢優(yōu)化
1)only與refer
only方法返回的是一個queryset對象,本質就是列表套數(shù)據(jù)對象
該對象內只含有only括號所指定的屬性(其他屬性也可以獲取,但是需要重新走數(shù)據(jù)庫查詢)
defer與only互為反關系,返回的是一個queryset對象,本質就是列表套數(shù)據(jù)對象;該對象只含有除了defer括號內所指定的屬性(括號內的屬性也可以獲取但是需要重新走數(shù)據(jù)庫)
2)select_related與prefetch_related
select_related括號內只能放外鍵字段,并且外鍵字段的類型只能是一對一或一對多,內部是聯(lián)表操作,會將外鍵關聯(lián)的表與當前表直接拼接起來,然后再執(zhí)行查詢操作,返回的結果也是一個queryset,列表套數(shù)據(jù)對象,該數(shù)據(jù)對象獲取當前表中的數(shù)據(jù)或者關聯(lián)表中的數(shù)據(jù),都不會再走數(shù)據(jù)庫;
prefetch_related 括號內外鍵字段全部支持,內部是子查詢,返回的結果也是一個queryset對象,列表套數(shù)據(jù)對象,該數(shù)據(jù)對象獲取當前表中的數(shù)據(jù)或者關聯(lián)表中的數(shù)據(jù),都不會再走數(shù)據(jù)庫;
第一個方法耗時主要耗在聯(lián)表操作,第二個方法耗時主要耗在查詢次數(shù);
choices字段
用在一些字段數(shù)據(jù)是可以明確列出所有的可能的;比如:性別,工作經(jīng)驗,學歷,婚否,客戶來源等;
1.先定義好對應關系;2.在通過字段的choices參數(shù)來指定關系。
gender_choices = (
(1,'male'),
(2,'female'),
(3,'others'),
)
gender = models.IntegerField(choices = gender_choices)
如果數(shù)據(jù)在你事先定義好的范圍內,可以通過get_字段名_display()拿到對應的解釋信息。
ajax
1.異步提交 2.局部刷新
ajax基本語法結構
現(xiàn)用的是基于JQuery封裝好的ajax,所以用ajax的時候,先導入jQuery;
$.ajax({ url:'', # 后端的地址,特性跟action一直,三種情況 type:'post', # 請求方式,小寫 data:{'username':'zhang',password:'123'}, # 提交的數(shù)據(jù) success:function(data){ # data異步提交的結果 # 回調機制返回的結果 # window.location.href = url } }) #基于ajax做數(shù)據(jù)交互,后端無論返回什么結果都會被回調函數(shù)捕獲,不會再影響整個頁面
前后端數(shù)據(jù)傳輸編碼格式
urlencoded
數(shù)據(jù)格式username=zhang&password=123
django針對符合urlencoded編碼格式的數(shù)據(jù),會自動解析并放到request.POST中;
formdata
form表單發(fā)送文件必須要指定的編碼格式
該編碼格式既可以發(fā)文件也可以發(fā)普通的鍵值對
django后端自動識別,將內部符合urlencoded編碼格式的數(shù)據(jù),自動解析并將文件類型的數(shù)據(jù)解析封裝到request.FILES中
application/json
ajax可以發(fā)送json格式的數(shù)據(jù),form表單不支持
#注意:數(shù)據(jù)類型和編碼格式要保證一致性
ajax如何發(fā)送json格式的數(shù)據(jù)
需要在前端新增一個參數(shù)
contentType:'application/json'
需要將數(shù)據(jù)序列化成json格式的字符串
JSON.stringfy({'username':'zhang','password':'123'})
注意:django后端針對json格式的數(shù)據(jù),不會做任何處理,原封不動的在放request.body內
ajax發(fā)送文件(不單單可以發(fā)送文件,也可以發(fā)送普通鍵值對)
建議借助原生js的內置對象幫你做數(shù)據(jù)攜帶
1).先生成一個內置對象
var MyFormData = new FormData();
2).然后朝該對象內添加數(shù)據(jù)(普通鍵值對和文件均可)
普通鍵值對
MyFormData.append('name','value')
MyFormData.append('name1','value1')
MyFormData.append('name2','value2')
文件數(shù)據(jù)
如何獲取input文件標簽內文件數(shù)據(jù)
var MyFileobj = $("input[type='file']")[0].files[0];
3.需要額外指定兩個參數(shù)
contentType:false, # 不指定任何編碼,對象自帶編碼 django能夠識別;
processData:false, # 瀏覽器不需要對數(shù)據(jù)進行任何處理
django能夠識別對象中的普通的鍵值對和文件對象,然后分別放到不同的方法POST和FILES中;
感謝各位的閱讀!關于“Django查詢優(yōu)化的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
分享標題:Django查詢優(yōu)化的示例分析-創(chuàng)新互聯(lián)
文章轉載:http://sd-ha.com/article46/jjphg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供標簽優(yōu)化、企業(yè)建站、ChatGPT、自適應網(wǎng)站、做網(wǎng)站、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內容