码迷,mamicode.com
首页 > 其他好文 > 详细

django小知识(1)

时间:2019-10-28 20:47:49      阅读:74      评论:0      收藏:0      [点我收藏+]

标签:一个   www   添加   序列化   聚合   tle   信息   告诉   直接   

聚合查询
关键字: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)

标签:一个   www   添加   序列化   聚合   tle   信息   告诉   直接   

原文地址:https://www.cnblogs.com/abdm-989/p/11755186.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!