Django查詢優(yōu)化及ajax編碼格式原理解析
orm查詢優(yōu)化
1)only與refer
only方法返回的是一個queryset對象,本質(zhì)就是列表套數(shù)據(jù)對象
該對象內(nèi)只含有only括號所指定的屬性(其他屬性也可以獲取,但是需要重新走數(shù)據(jù)庫查詢)
defer與only互為反關(guān)系,返回的是一個queryset對象,本質(zhì)就是列表套數(shù)據(jù)對象;該對象只含有除了defer括號內(nèi)所指定的屬性(括號內(nèi)的屬性也可以獲取但是需要重新走數(shù)據(jù)庫)
2)select_related與prefetch_related
select_related括號內(nèi)只能放外鍵字段,并且外鍵字段的類型只能是一對一或一對多,內(nèi)部是聯(lián)表操作,會將外鍵關(guān)聯(lián)的表與當(dāng)前表直接拼接起來,然后再執(zhí)行查詢操作,返回的結(jié)果也是一個queryset,列表套數(shù)據(jù)對象,該數(shù)據(jù)對象獲取當(dāng)前表中的數(shù)據(jù)或者關(guān)聯(lián)表中的數(shù)據(jù),都不會再走數(shù)據(jù)庫;
prefetch_related 括號內(nèi)外鍵字段全部支持,內(nèi)部是子查詢,返回的結(jié)果也是一個queryset對象,列表套數(shù)據(jù)對象,該數(shù)據(jù)對象獲取當(dāng)前表中的數(shù)據(jù)或者關(guān)聯(lián)表中的數(shù)據(jù),都不會再走數(shù)據(jù)庫;
第一個方法耗時主要耗在聯(lián)表操作,第二個方法耗時主要耗在查詢次數(shù);
choices字段
用在一些字段數(shù)據(jù)是可以明確列出所有的可能的;比如:性別,工作經(jīng)驗,學(xué)歷,婚否,客戶來源等;
1.先定義好對應(yīng)關(guān)系;2.在通過字段的choices參數(shù)來指定關(guān)系。
gender_choices = ( (1,’male’), (2,’female’), (3,’others’),)gender = models.IntegerField(choices = gender_choices)
如果數(shù)據(jù)在你事先定義好的范圍內(nèi),可以通過get_字段名_display()拿到對應(yīng)的解釋信息。
ajax
1.異步提交 2.局部刷新
ajax基本語法結(jié)構(gòu)
現(xiàn)用的是基于JQuery封裝好的ajax,所以用ajax的時候,先導(dǎo)入jQuery;
$.ajax({url:’’, # 后端的地址,特性跟action一直,三種情況type:’post’, # 請求方式,小寫data:{’username’:’zhang’,password:’123’}, # 提交的數(shù)據(jù)success:function(data){ # data異步提交的結(jié)果# 回調(diào)機(jī)制返回的結(jié)果# window.location.href = url}})#基于ajax做數(shù)據(jù)交互,后端無論返回什么結(jié)果都會被回調(diào)函數(shù)捕獲,不會再影響整個頁面
前后端數(shù)據(jù)傳輸編碼格式
urlencoded數(shù)據(jù)格式username=zhang&password=123django針對符合urlencoded編碼格式的數(shù)據(jù),會自動解析并放到request.POST中;formdataform表單發(fā)送文件必須要指定的編碼格式該編碼格式既可以發(fā)文件也可以發(fā)普通的鍵值對django后端自動識別,將內(nèi)部符合urlencoded編碼格式的數(shù)據(jù),自動解析并將文件類型的數(shù)據(jù)解析封裝到request.FILES中application/jsonajax可以發(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內(nèi)
ajax發(fā)送文件(不單單可以發(fā)送文件,也可以發(fā)送普通鍵值對)
建議借助原生js的內(nèi)置對象幫你做數(shù)據(jù)攜帶
1).先生成一個內(nèi)置對象
var MyFormData = new FormData();
2).然后朝該對象內(nèi)添加數(shù)據(jù)(普通鍵值對和文件均可)
普通鍵值對
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.需要額外指定兩個參數(shù)
contentType:false, # 不指定任何編碼,對象自帶編碼 django能夠識別;
processData:false, # 瀏覽器不需要對數(shù)據(jù)進(jìn)行任何處理
django能夠識別對象中的普通的鍵值對和文件對象,然后分別放到不同的方法POST和FILES中;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 將properties文件的配置設(shè)置為整個Web應(yīng)用的全局變量實現(xiàn)方法2. 一文秒懂idea的git插件跟翻譯插件3. XML解析錯誤:未組織好 的解決辦法4. 解決ajax的delete、put方法接收不到參數(shù)的問題方法5. docker compose idea CreateProcess error=2 系統(tǒng)找不到指定的文件的問題6. ASP實現(xiàn)加法驗證碼7. jsp實現(xiàn)登錄驗證的過濾器8. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera9. XML入門的常見問題(一)10. XML入門的常見問題(四)
