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 - 弦圈
更多其他趣味内容: 弦圈 - 找到属于你的圈子

相关推荐
不断高歌2 小时前
MySQL基础随堂笔记3
数据库·mysql
筵陌2 小时前
MySQL表的增删查改(上)
数据库·mysql
paperxie_xiexuo2 小时前
学术与职场演示文稿的结构化生成机制探析:基于 PaperXie AI PPT 功能的流程解构与适用性研究
大数据·数据库·人工智能·powerpoint
筵陌3 小时前
MySQL表的约束
数据库·mysql
UCoding3 小时前
我们来学mysql -- ReadView工作原理
数据库·mysql·readview工作原理
angushine3 小时前
解决MySQL慢日志输出问题
android·数据库·mysql
合作小小程序员小小店3 小时前
网页开发,在线%旧版本旅游管理%系统,基于eclipse,html,css,jquery,servlet,jsp,mysql数据库
java·数据库·servlet·eclipse·jdk·旅游·jsp
q***46523 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
腾讯云数据库3 小时前
「腾讯云 NoSQL 技术」之 Redis 篇|揭晓腾讯云Redis水平扩缩容极致流畅背后的技术玄机
数据库
SelectDB4 小时前
压缩率提升 48%,详解 Apache Doris 存储压缩优化之道|Deep Dive
数据库·开源·github