首页 > 其他分享 >django 聚合查询 分组查询 f查询 q查询

django 聚合查询 分组查询 f查询 q查询

时间:2022-12-18 18:12:54浏览次数:47  
标签:__ models res price django objects 分组 查询

目录

今日内容详细

图书管理系统讲解

1.表设计
	先考虑普通字段再考虑外键字段
	数据库迁移、测试数据录入
2.首页展示
3.书籍展示
4.书籍添加
5.书籍编辑
	后端如何获取用户想要编辑的数据、前端如何展示出待编辑的数据
6.书籍删除

聚合查询

聚合函数:Max Min Sum Count Avg
在ORM中支持单独使用聚合函数  aggregate 

from django.db.models import Max, Min, Sum, Count, Avg
res = models.Book.objects.aggregate(Max('price'), Count('pk'), 最小价格=Min('price'), allPrice=Sum('price'),平均价格=Avg('price'))
print(res)

分组查询

"""
如果执行orm分组查询报错 并且有关键字sql_mode strict mode
	移除sql_mode中的only_full_group_by
"""
# 分组查询
    # 统计每一本书的作者个数
    # res = models.Book.objects.annotate(author_num=Count('authors__pk')).values('title', 'author_num')
    # print(res)
    # 统计出每个出版社卖的最便宜的书的价格
    # res = models.Publish.objects.annotate(min_price=Min('book__price')).values('name', 'min_price')
    # print(res)
    # 统计不止一个作者的图书
    # 1.先统计每本书的作者个数
    # res = models.Book.objects.annotate(author_num=Count('authors__pk'))
    # 2.筛选出作者个数大于1的数据
    # res = models.Book.objects.annotate(author_num=Count('authors__pk')).filter(author_num__gt=1).values('title',
    #                                                                                                     'author_num')
    # print(res)
    # 查询每个作者出的书的总价格
    # res = models.Author.objects.annotate(总价=Sum('book__price'),count_book=Count('book__pk')).values('name','总价','count_book')
    # print(res)
    """
    models.表名.objects.annotate()                            按照表分组
    models.表名.objects.values('字段名').annotate()            按照values括号内指定的字段分组
    """
    res = models.Book.objects.values('publish_id').annotate(count_pk=Count('pk')).values('publish_id', 'count_pk')
    print(res)

F与Q查询

# 1.查询库存数大于卖出数的书籍
'''当查询条件不是明确的 也需要从数据库中获取 就需要使用F查询'''
from django.db.models import F
# res = models.Book.objects.filter(kucun__gt=F('maichu'))
# print(res)
# 2.将所有书的价格涨800
# models.Book.objects.update(price=F('price') + 800)
# 3.将所有书的名称后面追加爆款
from django.db.models.functions import Concat
from django.db.models import Value
models.Book.objects.update(title=Concat(F('title'), Value('新款')))


# 查询主键是1或者价格大于2000的书籍
# res = models.Book.objects.filter(pk=1, price__gt=2000)  # 逗号默认是and关系
from django.db.models import Q
# res = models.Book.objects.filter(Q(pk=1), Q(price__gt=2000))  # 逗号是and
# res = models.Book.objects.filter(Q(pk=1) | Q(price__gt=2000))  # |是or
res = models.Book.objects.filter(~Q(pk=1) | Q(price__gt=2000))  # ~是not
print(res.query)

标签:__,models,res,price,django,objects,分组,查询
From: https://www.cnblogs.com/yong-wu/p/16990717.html

相关文章

  • 模型层之聚合查询,分组查询,F与Q查询
    目录模型层之聚合查询,分组查询,F与Q查询今日概要今日内容详细聚合查询分组查询F与Q查询模型层之聚合查询,分组查询,F与Q查询今日概要聚合查询分组查询F与Q查询今日内......
  • 聚合查询 分组查询 F与Q查询 添加新字段
    目录聚合查询aggregate聚合函数起别名分组查询annotate注释函数起别名分组查询报错分组查询练习总结添加新字段F与Q查询F查询字符串拼接concat方法Q查询Q查询之and关系Q......
  • 聚合查询、分组查询、F与Q查询
    聚合查询aggregate(*args,**kwargs)1.基本介绍介绍:聚合查询通常情况下都是配合分组一起使用的.如果你只想使用聚合函数,但是不想分组,那么就应该使用aggregate.使......
  • 配置Django后端跨域
    一:安装django-cors-headers库 pipinstalldjango-cors-headers二:配置settings.py1.注册APP(在rest_framework后面添加)#注册APPINSTALLED_APPS=['rest_......
  • DQL查询数据
    DQL查询数据!1.DQL(DataQueryLanguage数据查询语言)SELECT数据库中最核心的语言,最重要的语句狂神MySQL中p16school.sql文件(数据为部分数据)/*SQLyogUlti......
  • Mysql 中的升序、降序以及随机查询
    1.升序selecttime,Afromtable1orderbytimeasclimit10;+---------------------+---------+|time               |A      |+------......
  • django7
    图书管理系统讲解1.表设计 先考虑普通字段再考虑外键字段 数据库迁移、测试数据录入2.首页展示3.书籍展示4.书籍添加5.书籍编辑 后端如何获取用户想要编辑的数据、......
  • django框架(五)
    将某个html的部分提前写好之后很多html页面想使用就可以导入直接在要导入的地方用以下代码即可:{%include'myform.html'%}#仅适用于页面某个小的区域,不适......
  • django框架(六)
    ORM执行SQL语句有时候ORM的操作效率可能偏低,其实也支持自己写SQL语句#方式1:#注意表名res=models.User.objects.raw('select*fromapp01_userwhereid<3;')......
  • django框架(部分讲解)
    图书管理系统讲解前期准备工作修改配置文件表设计考虑普通字段考虑外键字段数据库迁移连接数据库插入数据测试数据录入首页展示创建一个h......