ORM聚合查询与原生数据库操作

1.聚合查询

分类分为整表聚合与分组聚合。

1.1 整表聚合

先导入from django.db.models import *
聚合函数Sum Avg Count Max Min

语法:
MyModel.objects.aggregate(结果变量=聚合函数(’列‘))
返回字典:{结果变量名:值}

1.2 分组聚合

先分组,再聚合

1.2.1 先分组

MyModel.objects.values(‘列1’,’列2‘)

在这里插入图片描述

1.2.2 用annotate聚合

在这里插入图片描述

2. 原生数据库操作

防止sql注入,不建议使用
raw返回RawQuerySet只用做循环
查询:

res = Book.objects.raw('select * from bookstore_book where id =%s'%(id))

2.1 游标

完全跨过模型类操作数据库,查改删

2.1.1 导入cursor
from django.db import connection
2.1.2 创建cursor对象

通常使用with语句,便于释放cursor资源

from django.db import connection
with connection.cusor() as cur:
	cur.exectue('SQL','拼接参数')

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

银行上班的法学程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值