day57 模型层中过滤器和数据库增删改查进阶

news/2024/7/10 23:17:16 标签: 数据库, django, jquery

昨日内容回顾

三板斧
在视图文件中写的函数不能没有返回值,并且返回值还要是HttpResponse对象
render  redirect------------------->HttpResponse对象
序列化模块
import json
json.dumps
json.loads
​
from django.http import JsonResponse
class JsonResponse(HttpResponse):
    def __init__(self,json_dumps_param=None)
        json.dumps(**json_dumps_param)
        
def index(request):
    l = [1, 2, 3, 4]
    # 默认情况下只能够序列化字典,其他数据类型要想被序列化,需要加safe参数
    return JsonResponse({}, json_dumps_param={'ensure_ascii':False},safe=False)
form表单上传文件
1. form表单上传文件满足的条件
    请求方式是post
    编码格式:form-data
    
    
2. Django后端在哪里取出文件数据
    request.FILES
    request.POST
    request.body
    file_obj=request.FILES.get('myfile')
    file_obj.name # 文件名,自己重命名文件名
    with open;
3. request对象的方法
    request.method
    request.POST.get()
    request.POST.getlist()
    request.GET.get()
    request.GET.getlist()
    request.FILES
    request.path
    request.path_info  # 不能接收参数,接收的是后缀
    request.get_full_path() # 也能够接收参数
    
CBV的书写
在视图文件中可以写类,以前写的都是函数
​
from django.views import View  
​
class Login(View):
    def get(self, request):
        pass
    
    def post(self, request):
        pass
    
    def login(self):
        pass
    
"""一周的drf课程都是类和对象,都是方法"""
# 路由
url('/index/', view.Login.as_view())
​
# 源码的分析:自己去看个两三遍,注释写一写
...
模板之变量
"""Python的数据类型基本都支持放到模板中使用"""
# 在模板中取值的时候:使用的是点语法(.)
# 模板中得函数调用的时候不要加括号,自动加括号,你只需要写函数名

今日内容概要

模板层

  • 模板之过滤器

  • 模板之标签(if else for)

  • 模板之继承

  • 导入模板

模型层

  • 单表的操作

  • 十几种常见的查询方法

  • 基于下划线的查询方法

  • 外键字段的增删改查

  • 正反向查询(多表跨表)

今日内容详细

模板之过滤器
# 过滤器给我们提供的有六十多个,但是我们只需要掌握10个以内即可
# 过滤器名称就是函数名
​
语法:
    {{ obj|filter__name:param }}  变量名字|过滤器名称:变量
模板之标签
# {% if %}会对一个变量求值,如果它的值是True(存在、不为空、且不是boolean类型的false值),对应的内容块会输出。
​
{% if num > 100 or num < 0 %}
    <p>无效</p>
{% elif num > 80 and num < 100 %}
    <p>优秀</p>
{% else %}
    <p>凑活吧</p>
{% endif %}
​
if语句支持 and 、or、==、>、<、!=、<=、>=、in、not in、is、is not判断。
​
{% for key,val in dic.items %}
    <p>{{ key }}:{{ val }}</p>
{% endfor %}
​
{% for foo in d.keys %}
    <p>{{ foo }}</p>
{% endfor %}
​
{% for foo in d.values %}
    <p>{{ foo }}</p>
{% endfor %}
​
{% for foo in d.items %}
    <p>{{ foo }}</p>
{% endfor %}
​
forloop.counter            The current iteration of the loop (1-indexed) 当前循环的索引值(从1开始)
forloop.counter0           The current iteration of the loop (0-indexed) 当前循环的索引值(从0开始)
forloop.revcounter         The number of iterations from the end of the loop (1-indexed) 当前循环的倒序索引值(从1开始)
forloop.revcounter0        The number of iterations from the end of the loop (0-indexed) 当前循环的倒序索引值(从0开始)
forloop.first              True if this is the first time through the loop 当前循环是不是第一次循环(布尔值)
forloop.last               True if this is the last time through the loop 当前循环是不是最后一次循环(布尔值)
forloop.parentloop         本层循环的外层循环
​
d = {'username':'kevin','age':18,'info':'这个人有点意思','hobby':[111,222,333,{'info':'NB'}]}
​
# with起别名
{% with d.hobby.3.info as nb  %}
    <p>{{ nb }}</p>
    在with语法内就可以通过as后面的别名快速的使用到前面非常复杂获取数据的方式
    <p>{{ d.hobby.3.info }}</p>
{% endwith %}
​
​
{% with total=business.employees.count %}
    {{ total }} employee{{ total|pluralize }}
{% endwith %}
不要写成as
模板的继承和导入
{% extends 'home.html' %}
​
{% block css %}
    <style>
        h1{
            color: red;
        }
    </style>
{% endblock %}
​
​
{% block js %}
    <script>
        alert('login')
    </script>
{% endblock %}
​
{% include 'haha.html' %}
模型层(跟数据库打交道的,重点核心)
1. 单表的操作
create
update
delete
all
first
filter
# django自带的sqlite3数据库对日期格式不是很敏感 处理的时候容易出错
# 增
    # res = models.User.objects.create(name='jason',age=18,register_time='2002-1-21')
    # print(res)
    # import datetime
    # ctime = datetime.datetime.now()
    # user_obj = models.User(name='egon',age=84,register_time=ctime)
    # user_obj.save()
​
    # 删
    # res = models.User.objects.filter(pk=2).delete()
    # print(res)
    """
    pk会自动查找到当前表的主键字段 指代的就是当前表的主键字段
    用了pk之后 你就不需要指代当前表的主键字段到底叫什么了
        uid
        pid
        sid
        ...
    """
    # user_obj = models.User.objects.filter(pk=1).first()
    # user_obj.delete()
​
    # 修改
    # models.User.objects.filter(pk=4).update(name='egonDSB')
​
    # user_obj = models.User.objects.get(pk=4)
    # user_obj = models.User.objects.filter(pk=6)
    """
    get方法返回的直接就是当前数据对象
    但是该方法不推荐使用
        一旦数据不存在该方法会直接报错
        而filter则不会
            所以我们还是用filter
    """
    # user_obj.name = 'egonPPP'
    # user_obj.save()
常见的十几种查询方法
# 必知必会13条
    # 1.all()  查询所有数据
​
    # 2.filter()     带有过滤条件的查询
    # 3.get()        直接拿数据对象 但是条件不存在直接报错
    # 4.first()      拿queryset里面第一个元素
    # res = models.User.objects.all().first()
    # print(res)
    # 5.last()
    # res = models.User.objects.all().last()
    # print(res)
​
    # 6.values()  可以指定获取的数据字段  select name,age from ...     列表套字典
    # res = models.User.objects.values('name','age')  # <QuerySet [{'name': 'jason', 'age': 18}, {'name': 'egonPPP', 'age': 84}]>
    # print(res)
    # 7.values_list()  列表套元祖
    # res = models.User.objects.values_list('name','age')  # <QuerySet [('jason', 18), ('egonPPP', 84)]>
    # print(res)
    # """
    #  # 查看内部封装的sql语句
    #  上述查看sql语句的方式  只能用于queryset对象
    #  只有queryset对象才能够点击query查看内部的sql语句
    #
    # """
    # 8.distinct()  去重
    # res = models.User.objects.values('name','age').distinct()
    # print(res)
    """
    去重一定要是一模一样的数据
    如果带有主键那么肯定不一样 你在往后的查询中一定不要忽略主键
    
    """
    # 9.order_by()
    # res = models.User.objects.order_by('age')  # 默认升序
    # res = models.User.objects.order_by('-age')  # 降序
    #
    # print(res)
    # 10.reverse()  反转的前提是 数据已经排过序了  order_by()
    # res = models.User.objects.all()
    # res1 = models.User.objects.order_by('age').reverse()
    # print(res,res1)
​
    # 11.count()  统计当前数据的个数
    # res = models.User.objects.count()
    # print(res)
    # 12.exclude()  排除在外
    # res = models.User.objects.exclude(name='jason')
    # print(res)
​
    # 13.exists()  基本用不到因为数据本身就自带布尔值  返回的是布尔值
    # res = models.User.objects.filter(pk=10).exists()
    # print(res)
测试脚本
"""
当你只是想测试django中的某一个py文件内容 那么你可以不用书写前后端交互的形式
而是直接写一个测试脚本即可
​
脚本代码无论是写在应用下的tests.py还是自己单独开设py文件都可以
"""
# 测试环境的准备 去manage.py中拷贝前四行代码 然后自己写两行
import os
import sys
​
if __name__ == "__main__":
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "day64.settings")
    import django
    django.setup()
    # 在这个代码块的下面就可以测试django里面的单个py文件了
查看内部sql语句的方式
# 方式1
res = models.User.objects.values_list('name','age')  # <QuerySet [('jason', 18), ('egonPPP', 84)]>
print(res.query)
queryset对象才能够点击query查看内部的sql语句
​
# 方式2:所有的sql语句都能查看
# 去配置文件中配置一下即可
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console':{
            'level':'DEBUG',
            'class':'logging.StreamHandler',
        },
    },
    'loggers': {
        'django.db.backends': {
            'handlers': ['console'],
            'propagate': True,
            'level':'DEBUG',
        },
    }
}
基于双下划线的查询
# 双下划线查询
    # 1 年龄大于35岁的数据
    # res = models.User.objects.filter(age__gt=35)
    # print(res)
    # 2 年龄小于35岁的数据
    # res = models.User.objects.filter(age__lt=35)
    # print(res)
    # 大于等于 小于等于
    # res = models.User.objects.filter(age__gte=32)
    # print(res)
    # res = models.User.objects.filter(age__lte=32)
    # print(res)
​
    # 年龄是18 或者 32 或者40
    # res = models.User.objects.filter(age__in=[18,32,40])
    # print(res)
​
    # 年龄在18到40岁之间的  首尾都要
    # res = models.User.objects.filter(age__range=[18,40])
    # print(res)
​
    # 查询出名字里面含有s的数据  模糊查询
    # res = models.User.objects.filter(name__contains='s')
    # print(res)
    #
    # 是否区分大小写  查询出名字里面含有p的数据  区分大小写
    # res = models.User.objects.filter(name__contains='p')
    # print(res)
    # 忽略大小写
    # res = models.User.objects.filter(name__icontains='p')
    # print(res)
​
    # res = models.User.objects.filter(name__startswith='j')
    # res1 = models.User.objects.filter(name__endswith='j')
    #
    # print(res,res1)
​
​
    # 查询出注册时间是 2020 1月
    # res = models.User.objects.filter(register_time__month='1')
    # res = models.User.objects.filter(register_time__year='2020')

http://www.niftyadmin.cn/n/5187093.html

相关文章

EtherCAT从站EEPROM分类附加信息详解:SM(同步管理器)

0 工具准备 1.EtherCAT从站EEPROM数据&#xff08;本文使用DE3E-556步进电机驱动器&#xff09;1 分类附加信息——SM&#xff08;同步管理器&#xff09; 1.1 分类附加信息规范 在EEPROM字64开始的区域存储的是分类附加信息&#xff0c;这里存储了包括设备信息、SM配置、FM…

4-为什么有了gil锁还要互斥锁?进程,线程和协程 以及进程,线程和协程的使用场景、什么是鸭子类型、并行和并发

1 为什么有了gil锁还要互斥锁&#xff1f; 1.1 并行和并发 2 进程&#xff0c;线程和协程 。代码如何实现&#xff1f;你在哪里用过 &#xff1f; 2.1 进程 2.2 线程 2.3 协程 2.4 进程&#xff0c;线程和协程的使用场景 3 什么是鸭子类型 1 为什么有了gil锁还要互斥锁&#…

Linux编译报错在此处初始化后被初始化

1.代码 2.问题 在Windows编译不会告警&#xff0c;在Linux编译会告警 3.解决 初始化列表的排列顺序按成员变量的声明顺序排 4.原因 因为列表初始化时&#xff0c;实际的执行顺序是按照成员变量的声明顺序初始化&#xff0c;跟初始化列表的代码排列顺序无关&#xff0c;当…

基于SSM的宠物综合服务平台的设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

读取Json BugFix

遇到的错误如下所示&#xff1a; 遇到的错误如下所示&#xff1a;File ~/miniconda3/lib/python3.9/json/decoder.py:353, in JSONDecoder.raw_decode(self, s, idx)344 """Decode a JSON document from s (a str beginning with345 a JSON document) and retu…

STM32中断看这一篇就够了

&#x1f64c;秋名山码民的主页 &#x1f602;oi退役选手&#xff0c;Java、大数据、单片机、IoT均有所涉猎&#xff0c;热爱技术&#xff0c;技术无罪 &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; 获取源码&#xff0c;添加WX 目录 1. 前言…

基于django电影推荐系统

基于django电影推荐系统 摘要 该Django电影推荐系统是一个简单而基础的框架&#xff0c;旨在展示系统的基本组件。系统包括两个主要模型&#xff0c;即Movie和Rating&#xff0c;用于存储电影信息和用户评分。视图层包括展示电影列表和电影详情的功能&#xff0c;使用模板进行页…

【Axure高保真原型】附件卡片

今天和大家分享附件卡片的原型模板&#xff0c;点击对应文件的卡片&#xff0c;如果浏览器支持读取该文件&#xff0c;就可以直接打开查看文件内容&#xff0c;否则就可以下载该文件。那这个模板是用中继器制作的&#xff0c;所以使用也很方便&#xff0c;只需要在中继器表格填…