Django对RawQuerySet进行计数

提问

你好,我使用的是django 1.2,然后我想知道如何对原生查询集(RawQuerySet)的行进行计数。

惯例的.count()方法行不通。

这是我的查询

python 复制代码
query = "SELECT *, ((ACOS(SIN(%s * PI() / 180) * SIN(lat * PI() / 180) + COS(%s * PI() / 180) * COS(lat * PI() / 180) * COS((%s - lon) * PI() / 180)) * 180 / PI()) * 60 * 1.1515) AS distance FROM app_car WHERE price BETWEEN %s AND %s HAVING distance<=%s ORDER BY distance ASC"

cars = Car.objects.raw(query, [lat, lat, lon, min_price, max_price, miles])

return HttpResponse( cars )

然后它的返回值是

python 复制代码
Car_Deferred_model_id_user_id object

大家有什么想法吗?

回答1

使用'len()'函数,这会带来:

python 复制代码
query = "SELECT *, ((ACOS(SIN(%s * PI() / 180) * SIN(lat * PI() / 180) + COS(%s * PI() / 180) * COS(lat * PI() / 180) * COS((%s - lon) * PI() / 180)) * 180 / PI()) * 60 * 1.1515) AS distance FROM app_car WHERE price BETWEEN %s AND %s HAVING distance<=%s ORDER BY distance ASC"

cars = Car.objects.raw(query, [lat, lat, lon, min_price, max_price, miles])

return HttpResponse(len(list(cars))

另外:这里有一些关于Django 1.2 Model.objects.raw()方法的有用信息: http://djangoadvent.com/1.2/smoothing-curve/ 【看起来该网站可能已经过期,但Internet Archive将其保存在:http://web.archive.org/web/20110513122309/http://djangoadvent.com/1.2/smoothing-curve/

欢迎来弦圈一起翻译StackOverflow等国外编程内容👇👇👇
翻译原文: Django对RawQuerySet进行计数
更多Django相关内容: Django - 弦圈
更多其他趣味内容: 弦圈 - 找到属于你的圈子

相关推荐
梦想的颜色15 小时前
Redis数据类型全解析:从底层原理到生产实战
运维·数据库·redis·缓存·高并发·分布式锁·数据类型
C137的本贾尼15 小时前
InnoDB 的物理世界:表空间、段、区与页
数据库
JdSnE27zv15 小时前
EF Code First学习笔记:数据库创建
数据库·笔记·学习
我是一颗柠檬15 小时前
【Redis】Redis性能优化Day14(2026年)
数据库·redis·性能优化
程序员老油条15 小时前
用 AI 生成复杂 SQL:LangChain4j + 本地模型实践
数据库·人工智能·sql
IT邦德15 小时前
Oracle 26ai RAC 通过gold image RU打补丁
数据库·oracle
smith成长之旅15 小时前
08 | Mem0 框架分析: BM25 的 Sigmoid 归一化
数据库·python·算法
C137的本贾尼16 小时前
MySQL 整体架构与存储引擎对比
数据库·mysql·架构
C137的本贾尼16 小时前
【实战】分析一张真实业务表的 InnoDB 存储结构
java·大数据·数据库
超梦dasgg16 小时前
亿级数据 不停服务平滑迁移(生产环境实战方案)
java·数据库