Django查询优化及ajax编码格式原理解析


Posted in Python onMarch 25, 2020

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中;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python获取文件ssdeep值的方法
Oct 05 Python
详解Python中 __get__和__getattr__和__getattribute__的区别
Jun 16 Python
numpy实现合并多维矩阵、list的扩展方法
May 08 Python
redis之django-redis的简单缓存使用
Jun 07 Python
使用python将请求的requests headers参数格式化方法
Jan 02 Python
解决nohup执行python程序log文件写入不及时的问题
Jan 14 Python
Python Web框架之Django框架cookie和session用法分析
Aug 16 Python
python导入不同目录下的自定义模块过程解析
Nov 18 Python
python利用opencv实现SIFT特征提取与匹配
Mar 05 Python
python多进程下的生产者和消费者模型
May 07 Python
浅谈numpy中np.array()与np.asarray的区别以及.tolist
Jun 03 Python
Python如何将将模块分割成多个文件
Aug 04 Python
python使用pyecharts库画地图数据可视化的实现
Mar 25 #Python
python实现3D地图可视化
Mar 25 #Python
简单了解django处理跨域请求最佳解决方案
Mar 25 #Python
python3利用Axes3D库画3D模型图
Mar 25 #Python
PyCharm 2020 激活到 2100 年的教程
Mar 25 #Python
Django用数据库表反向生成models类知识点详解
Mar 25 #Python
Python动态强类型解释型语言原理解析
Mar 25 #Python
You might like
在VS2008中编译MYSQL5.1.48的方法
2010/07/03 PHP
几种有用的变型 PHP中循环语句的用法介绍
2012/01/30 PHP
windows下PHP_intl.dll正确配置方法(apache2.2+php5.3.5)
2014/01/14 PHP
PHP图片处理之使用imagecopy函数添加图片水印实例
2014/11/19 PHP
php+Mysqli利用事务处理转账问题实例
2015/02/11 PHP
joomla数据库操作示例代码
2016/01/06 PHP
JS按位非(~)运算符与~~运算符的理解分析
2011/07/31 Javascript
jquery map方法使用示例
2014/04/23 Javascript
JavaScript开发人员的10个关键习惯小结
2014/12/05 Javascript
js实现无缝滚动图
2017/02/22 Javascript
Vue中父组件向子组件通信的方法
2017/07/11 Javascript
详解vue-cli构建项目反向代理配置
2017/09/07 Javascript
关于Vue单页面骨架屏实践记录
2017/12/13 Javascript
vue.js实现格式化时间并每秒更新显示功能示例
2018/07/07 Javascript
JS数组方法shift()、unshift()用法实例分析
2020/01/18 Javascript
python实现分页效果
2017/10/25 Python
TensorFlow在MAC环境下的安装及环境搭建
2017/11/14 Python
python实现基于SVM手写数字识别功能
2020/05/27 Python
python操作excel的包(openpyxl、xlsxwriter)
2018/06/11 Python
python如何把字符串类型list转换成list
2020/02/18 Python
Python实现猜年龄游戏代码实例
2020/03/25 Python
Django Channel实时推送与聊天的示例代码
2020/04/30 Python
Perfume’s Club中文官网:西班牙美妆在线零售品牌
2020/08/24 全球购物
办公文员的工作岗位职责
2013/11/12 职场文书
终端业务员岗位职责
2013/11/27 职场文书
销售冠军获奖感言
2014/02/03 职场文书
婚前协议书范本
2014/04/15 职场文书
小学语文教研活动总结
2014/07/01 职场文书
教师批评与自我批评总结
2014/10/16 职场文书
客服专员岗位职责范本
2015/04/07 职场文书
国王的演讲观后感
2015/06/03 职场文书
职工食堂管理制度
2015/08/06 职场文书
2016大学生优秀志愿者事迹材料
2016/02/25 职场文书
Go 自定义package包设置与导入操作
2021/05/06 Golang
MySQL和Oracle批量插入SQL的通用写法示例
2021/11/17 MySQL
apache ftpserver搭建ftp服务器
2022/05/20 Servers