Django查詢優化及ajax編碼格式原理解析
orm查詢優化
1)only與refer
only方法返回的是一個queryset對象,本質就是列表套數據對象
該對象內只含有only括號所指定的屬性(其他屬性也可以獲取,但是需要重新走數據庫查詢)
defer與only互為反關系,返回的是一個queryset對象,本質就是列表套數據對象;該對象只含有除了defer括號內所指定的屬性(括號內的屬性也可以獲取但是需要重新走數據庫)
2)select_related與prefetch_related
select_related括號內只能放外鍵字段,并且外鍵字段的類型只能是一對一或一對多,內部是聯表操作,會將外鍵關聯的表與當前表直接拼接起來,然后再執行查詢操作,返回的結果也是一個queryset,列表套數據對象,該數據對象獲取當前表中的數據或者關聯表中的數據,都不會再走數據庫;
prefetch_related 括號內外鍵字段全部支持,內部是子查詢,返回的結果也是一個queryset對象,列表套數據對象,該數據對象獲取當前表中的數據或者關聯表中的數據,都不會再走數據庫;
第一個方法耗時主要耗在聯表操作,第二個方法耗時主要耗在查詢次數;
choices字段
用在一些字段數據是可以明確列出所有的可能的;比如:性別,工作經驗,學歷,婚否,客戶來源等;
1.先定義好對應關系;2.在通過字段的choices參數來指定關系。
gender_choices = ( (1,’male’), (2,’female’), (3,’others’),)gender = models.IntegerField(choices = gender_choices)
如果數據在你事先定義好的范圍內,可以通過get_字段名_display()拿到對應的解釋信息。
ajax
1.異步提交 2.局部刷新
ajax基本語法結構
現用的是基于JQuery封裝好的ajax,所以用ajax的時候,先導入jQuery;
$.ajax({url:’’, # 后端的地址,特性跟action一直,三種情況type:’post’, # 請求方式,小寫data:{’username’:’zhang’,password:’123’}, # 提交的數據success:function(data){ # data異步提交的結果# 回調機制返回的結果# window.location.href = url}})#基于ajax做數據交互,后端無論返回什么結果都會被回調函數捕獲,不會再影響整個頁面
前后端數據傳輸編碼格式
urlencoded數據格式username=zhang&password=123django針對符合urlencoded編碼格式的數據,會自動解析并放到request.POST中;formdataform表單發送文件必須要指定的編碼格式該編碼格式既可以發文件也可以發普通的鍵值對django后端自動識別,將內部符合urlencoded編碼格式的數據,自動解析并將文件類型的數據解析封裝到request.FILES中application/jsonajax可以發送json格式的數據,form表單不支持#注意:數據類型和編碼格式要保證一致性
ajax如何發送json格式的數據
需要在前端新增一個參數
contentType:’application/json’
需要將數據序列化成json格式的字符串
JSON.stringfy({’username’:’zhang’,’password’:’123’})
注意:django后端針對json格式的數據,不會做任何處理,原封不動的在放request.body內
ajax發送文件(不單單可以發送文件,也可以發送普通鍵值對)
建議借助原生js的內置對象幫你做數據攜帶
1).先生成一個內置對象
var MyFormData = new FormData();
2).然后朝該對象內添加數據(普通鍵值對和文件均可)
普通鍵值對
MyFormData.append(’name’,’value’)MyFormData.append(’name1’,’value1’)MyFormData.append(’name2’,’value2’)
文件數據
如何獲取input文件標簽內文件數據
var MyFileobj = $('input[type=’file’]')[0].files[0];
3.需要額外指定兩個參數
contentType:false, # 不指定任何編碼,對象自帶編碼 django能夠識別;
processData:false, # 瀏覽器不需要對數據進行任何處理
django能夠識別對象中的普通的鍵值對和文件對象,然后分別放到不同的方法POST和FILES中;
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章: