Django查询优化及ajax编码格式原理解析
作者:jueyuanfengsheng 发布时间:2021-04-26 02:04:27
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=123
django针对符合urlencoded编码格式的数据,会自动解析并放到request.POST中;
formdata
form表单发送文件必须要指定的编码格式
该编码格式既可以发文件也可以发普通的键值对
django后端自动识别,将内部符合urlencoded编码格式的数据,自动解析并将文件类型的数据解析封装到request.FILES中
application/json
ajax可以发送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中;
来源:https://www.cnblogs.com/zhangchaocoming/p/11972843.html


猜你喜欢
- 本文实例讲述了Python实现的数据结构与算法之队列。分享给大家供大家参考。具体分析如下:一、概述队列(Queue)是一种先进先出(FIFO
- 本文实例讲述了Python微信企业号文本消息推送功能。分享给大家供大家参考,具体如下:企业号的创建、企业号应用的创建、组、tag、part就
- 在多数情况下,以增加文件大小代价来换连接数是有价值。而MHTML+dataURI = 省连接数,如果你不知道这是什么东东,可以看秦歌写的Da
- 先上代码,主要语句为np.where(b[c]==1),详细解释如下:import numpy as np b = np.array([[-
- array和asarray都可以将结构数据转化为ndarray,但是主要区别就是当数据源是ndarray时,array仍然会copy出一个副
- 本文只有代码,介绍了有关GUI界面的学生信息管理系统的实现。已经过调试没有很大问题。如有错误,还请批评指正。1.导入tkinter模块imp
- 使用ES做搜索引擎拉取数据的时候,如果数据量太大,通过传统的from + size的方式并不能获取所有的数据(默认最大记录数10000),因
- Python爬虫、数据分析、网站开发等案例教程视频免费在线观看https://space.bilibili.com/523606542Sel
- 枚举类Enum枚举类,在企业开发中用的比较多当我们需要定义常量时,一个办法是用大写的变量通过整数来定义,例如月份:# 当项目中需要使用12个
- 海量数据库的查询优化及分页算法方案 原出处不详 摘自:www.21php.com 随着“ * ”建设的逐步深入和 * 信息化的高
- Gittle是一个高级纯python git 库。构建在dulwich之上,提供了大部分的低层机制。Install itpip instal
- 本文实例讲述了Python实现清理微信僵尸粉功能。分享给大家供大家参考,具体如下:原理通过Pyhton调用itchat模块登录网页版微信,给
- 在网站的一些应用中需要提供用户直接打印页面的功能,最明显的就是电子优惠券,商家根据网站提供的模板输入内容,然后生成优惠券页面,用户打印这个页
- 简述公司使用gitlab 来托管代码,日常代码merge request 以及其他管理是交给测试,鉴于操作需经常打开网页,重复且繁琐,所以交
- <em>`mark` set('index','best','hot')<
- 本人python新手小白,记录学习过程中遇到的一些小问题。python 爬虫获取网页资源之前,联网是必须的,作为 python 中最常用的
- “你不必严格遵守这些原则,违背它们也不会被处以宗教刑罚。但你应当把这些原则看成警铃,若违背了其中的一条,那么警铃就会响起
- 本文实例讲述了python计算方程式根的方法。分享给大家供大家参考。具体实现方法如下:''' roots = pol
- 一、创建多对多1.学生表create table students ( id int not null primary
- 本文实例讲述了Python队列RabbitMQ 使用方法。分享给大家供大家参考,具体如下:目前的exchange的路由策略是:每个需要队列的