聚合查询

关键字:aggregate

from django.db.models import Max,Min,Count,Sum,Avg

分组查询

关键字:annotate

1.最简单的规律

models后面点什么 就是按什么分组

F与Q查询

from django.db.modles import F,Q

F 能够帮助你获取到表中字段所对应的数据

# 书籍的库存数与卖出数

models.Book.objects.filter(kucun__gt=F('maichu'))

因为filter过滤的条件的都是and连接

modesls.Book.objects.filter(Q(title='python'),Q(price=666))

modesls.Book.objects.filter(Q(title='python')|Q(price=666))

modesls.Book.objects.filter(~Q(title='python')|Q(price=666))

# Q进阶用法

q = Q()

q.connector = 'or'

q.children.append(('title','python'))

q.children.append(('title__icontains','python'))

q.children.append(('price',666))

models.Book.objects.filter(q) # 默认还是and关系

django中如何开启事务

from django.db import transaction

try:

with transaction.atomic():

# 事务操作

except BaseException as e:

print(e)

常见字段及参数

AutoField()

DateField()

DateTimeField()

auto_now

auto_now_add

TextField()

EmailField() varchar(...)

BooleanField() 传布尔值 存0/1

自定义char字段

class MyCharField(models.Field):

def db_type(self,connection):

return 'char(%s)'%self.max_length

orm查询优化

only

defer

select_related

prefetch_related

图书管理系统

书籍的增删改查

今日内容

choice参数

用户性别

用户学历

用户工作状态

客户来源

...

choices = (

(1,'male'),

(2,'female'),

(3,'others')

)

gender = models.IntegerField(choices=choices)

"""

1.如果我存的是上面元组中数字会怎么样

2.如果我存的数字不在元组范围内又会怎样

1.数字没有对应关系 是可以存的

"""

from app01 import models

user_obj = models.Userinfo.objects.filter(pk=4).first()

print(user_obj.username)

print(user_obj.gender)

# 针对choices字段 如果你想要获取数字所对应的中文 你不能直接点字段

# 固定句式 数据对象.get_字段名_display() 当没有对应关系的时候 该句式获取到的还是数字

print(user_obj.get_gender_display())

record_choices = (('checked', "已签到"),

('vacate', "请假"),

('late', "迟到"),

('noshow', "缺勤"),

('leave_early', "早退"),

)

record = models.CharField("上课纪录", choices=record_choices, default="checked",

score_choices = ((100, 'A+'),

(90, 'A'),

(85, 'B+'),

(80, 'B'),

(70, 'B-'),

(60, 'C+'),

(50, 'C'),

(40, 'C-'),

(0, ' D'),

(-1, 'N/A'),

(-100, 'COPY'),

(-1000, 'FAIL'),

)

score = models.IntegerField("本节成绩", choices=score_choices, default=-1)

MTV与MVC模型

django号称是MTV框架,其实他还是MVC框架

MTV:

M:models

T: templates

V: views

MVC:

M:models

V: views

C: contronner(路由匹配)

ajax(******)

异步提交

同步异步:描述的任务的提交方式

同步:提交任务之后 原地等待任务的返回结果 期间不干任何事儿

异步:提交任务之后 不愿地等待 直接执行下一行代码 任务的返回通过回调机制

阻塞非阻塞:程序的运行状态

程序运行的三状态图

局部刷新

一个页面 不是整体刷新 而是页面的某个地方局部刷新

Ajax是一门js的技术 基于原生js开发的,但是用原生的js写代码过于繁琐

我们在学的时候 只学如何用jQuery实现ajax

AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。

(这一特点给用户的感受是在不知不觉中完成请求和响应过程)

1.展示一个前端页面 页面上有三个输入框 前两个框输入数字 点击按钮朝后端发请求

页面不刷新的情况下 完成数字的加法运算

    <input type="text" id="t1"> + <input type="text" id="t2"> = <input type="text" id="t3">
<p>
<button id="b1">计算</button>
</p>
$('#b1').on('click',function () {
// 朝后端提交post数据
$.ajax({
// 1.到底朝后端哪个地址发数据
url:'', // 专门用来控制朝后端提交数据的地址 不写默认就是朝当前地址提交
// 2.到底发送什么请求
type:'post', // 专门制定ajax发送的请求方式
// 3.发送的数据到底是什么
data:{'t1':$('#t1').val(),'t2':$('#t2').val()},
// 4.异步提交的任务 需要通过回调函数来处理
success:function (data) { // data形参指代的就是异步提交的返回结果
// 通过DOM操作将内容 渲染到标签内容上
$('#t3').val(data)
}
})
})

Ajax传json格式数据

django后端针对json格式的数据 不会自动帮你解析 会直接原封不动的给你放到request.body中

你可以手动处理 获取数据

json_bytes = request.body

json_str = str(json_bytes,encoding='utf-8')

json_dict = json.loads(json_str)

# 注意点

1.指定contentType参数

contentType:'application/json',

2.要将你发送的数据 确保是json格式的

data:JSON.stringify({'username':'jason','password':'123'})

AJAX传文件

需要利用内置对象 Formdata

该对象既可以传普通的键值 也可以传文件

# 获取input获取用户上传文件的文件的内容

// 1.先通过jquery查找到该标签

// 2.将jquery对象转换成原生的js对象

// 3.利用原生js对象的方法 直接获取文件内容

$('#t3')[0].files[0]

\(('#b1').click(function () {
// 1.先生成一个formdata对象
var myFormData = new FormData();
// 2.朝对象中添加普通的键值
myFormData.append('username',\)("#t1").val());

myFormData.append('password',\(("#t2").val());
// 3.朝对象中添加文件数据
// 1.先通过jquery查找到该标签
// 2.将jquery对象转换成原生的js对象
// 3.利用原生js对象的方法 直接获取文件内容
myFormData.append('myfile',\)('#t3')[0].files[0]);

$.ajax({

url:'',

type:'post',

data:myFormData, // 直接丢对象

// ajax传文件 一定要指定两个关键性的参数

contentType:false, // 不用任何编码 因为formdata对象自带编码 django能够识别该对象

processData:false, // 告诉浏览器不要处理我的数据 直接发就行

success:function (data) {

alert(data)

}

})

})

ajax传文件需要注意的事项

1.利用formdata对象 能够简单的快速传输数据 (普通键值 + 文件)

2.有几个参数

data:formdata对象

contentType:false

processData:false

contentType前后端传输数据编码格式

form表单 默认的提交数据的编码格式是urlencoded

urlencoded

username=admin&password=123这种就是符合urlencoded数据格式

django后端针对username=admin&password=123的urlencoded数据格式会自动解析

将结果打包给request.POST 用户只需要从request.POST即可获取对应信息

formdata

django后端针对formdata格式类型数据 也会自动解析

但是不会方法request.POST中而是给你放到了request.FILES中

ajax ajax默认的提交数据的编码格式也是urlencoded

username=jason&password=123

总结:django后端针对不同的编码格式数据 会有不同的处理机制以及不同的获取该数据的方法

"""

前后端在做数据交互的时候 一定一定要表明你所发的的数据到底是什么格式

前段后交互 你不能骗人家

你的数据时什么格式 你就应该准确无误告诉别人是什么格式

"""

序列化组件

1.将用户表的数据 查询出来 返回给前端

给前端的是一个大字典 字典里面的数据的一个个的字段

from django.core import serializers

def ser(request):

user_queryset = models.Userinfo.objects.all()

[{},{},{},{}]

user_list = []

for user_obj in user_queryset:

user_list.append({

'username':user_obj.username,

'password':user_obj.password,

'gender':user_obj.get_gender_display(),

})

res = serializers.serialize('json',user_queryset)

print(res)

return render(request,'ser.html',locals())

ajax + sweetalert

$("#b55").click(function () {

swal({

title: "你确定要删除吗?",

text: "删除可就找不回来了哦!",

type: "warning",

showCancelButton: true, // 是否显示取消按钮

confirmButtonClass: "btn-danger", // 确认按钮的样式类

confirmButtonText: "删除", // 确认按钮文本

cancelButtonText: "取消", // 取消按钮文本

closeOnConfirm: false, // 点击确认按钮不关闭弹框

showLoaderOnConfirm: true // 显示正在删除的动画效果

},

function () {

var deleteId = 2;

$.ajax({

url: "/delete_book/",

type: "post",

data: {"id": deleteId},

success: function (data) {

if (data.code === 0) {

swal("删除成功!", "你可以准备跑路了!", "success");

} else {

swal("删除失败", "你可以再尝试一下!", "error")

}

}

})

});

})

参考博客:https://www.cnblogs.com/Dominic-Ji/p/9234099.html
参考链接:https://lipis.github.io/bootstrap-sweetalert/

django小知识(1)的更多相关文章

  1. django小知识(2)

    昨日内容回顾 1.choices参数 class Userinfo(models.Model): username = ... age = ... gender_choice = ( (1,'male ...

  2. django小知识

    def __str__: return self.name 在显示的时候,将原来显示的额object对象,显示成这个类的名字

  3. Django 2.0.7 使用小知识

    Django 2.0.3 使用小知识 运行环境: Python 3.6.4 Django 2.0.7 Django Admin中model显示为中文 定义model时,定义一个Meta对象,设置需要显 ...

  4. $Django 路飞之小知识回顾,Vue之样式element-ui,Vue绑定图片--mounted页面挂载--路由携带参数

    一 小知识回顾 1 级联删除问题 2 一张表关联多个表,比如有manytomanyfileds forignkey,基于对象查询存在的问题:反向查询的时候  表名小写_set.all()不知是哪个字段 ...

  5. 简述Python入门小知识

    如今的Python开发工程师很受企业和朋友们的青睐,现在学习Python开发的小伙伴也很多,本篇文章就和大家探讨一下Python入门小知识都有哪些. 扣丁学堂简述Python入门小知识Python培训 ...

  6. Django+小程序技术打造微信小程序助手 ✌✌

    Django+小程序技术打造微信小程序助手 (一个人学习或许会很枯燥,但是寻找更多志同道合的朋友一起,学习将会变得更加有意义✌✌) 从零到一的完整项目开发实战过程,项目开发聚焦重要知识点,先原理后实战 ...

  7. Django 小实例S1 简易学生选课管理系统 3 创建用户模型(model)

    Django 小实例S1 简易学生选课管理系统 第3节--创建用户模型(model) 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 本文涉及到的新 ...

  8. Django 小实例S1 简易学生选课管理系统 4 实现登录页面

    Django 小实例S1 简易学生选课管理系统 第4节--实现登录页面 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 本文涉及到的新的额外知识点: ...

  9. Django 小实例S1 简易学生选课管理系统 5 实现注册功能

    Django 小实例S1 简易学生选课管理系统 第5节--实现注册功能 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 本文涉及到的新的额外知识点: ...

随机推荐

  1. [技术博客]海报图片生成——小程序canvas画布

    目录 背景介绍 canvas简介 代码实现 难点讲解 圆角矩形裁剪失败之PS的妙用 编码不要过硬 对过长的文字进行截取 真机首次生成时字体不对 drawImage只能使用本地图片 背景介绍 目标:利用 ...

  2. 关于微信小程序前端Canvas组件教程

    关于微信小程序前端Canvas组件教程 微信小程序Canvas接口函数 ​ 上述为微信小程序Canvas的内部接口,通过熟练使用Canvas,即可画出较为美观的前端页面.下面是使用微信小程序画图的一些 ...

  3. [技术博客] JS正则活学活用

    正则基本语法 正则表达式(Regular Expression)是用单字符串来匹配一系列复合条件字符串的模式,对于乔姆斯基3型语法. 数学定义: 串行AB表示集合 {αβ | α ∈ A ,β ∈ B ...

  4. spark 基本操作(二)

    1.dataframe 基本操作 def main(args: Array[String]): Unit = { val spark = SparkSession.builder() .appName ...

  5. Spring的JdbcTemplate使用教程

    Spring对数据库的操作在jdbc上面做了基本的封装,让开发者在操作数据库时只需关注SQL语句和查询 结果处理器,即可完成功能(当然,只使用JdbcTemplate,还不能摆脱持久层实现类的编写). ...

  6. Visual Studio 调试 —— 附加到进程

    第一步:通过管理员方式打开想要附加到进程的项目. 第二步:在 “附加到进程” 对话框中的 “可用进程” 列表中,找到要附加到的程序.我的以 MyProgressTest 为例.选择调试 / 附加到进程 ...

  7. 【转帖】Linux文件夹对比并提取的差分文件技巧-rsync的妙用

    Linux文件夹对比并提取的差分文件技巧-rsync的妙用 [日期:2016-02-13] 来源:oschina.net  作者:mengshuai [字体:大 中 小] https://www.li ...

  8. SQL系列(十三)—— 关于表的DDL

    前面的文章一直都在讲述关于DML方面的SQL Statement.这篇文章来说说表方面的DDL: CREATE 创建表 ALTER 修改表 DROP 删除表 CREATE 1.语法 CREATE TA ...

  9. k8s-架构中各个组件介绍

    参考链接:https://github.com/opsnull/follow-me-install-kubernetes-cluster kubernetes 概述 1.kubernetes 是什么 ...

  10. gitblit搭建

    gitblit 1.8.0  + java7 下载安装java7 https://download.oracle.com/otn/java/jdk/7u80-b15/jdk-7u80-windows- ...