您的位置:首页 > 汽车 > 新车 > Django对RawQuerySet进行计数

Django对RawQuerySet进行计数

2025/1/5 14:54:55 来源:https://blog.csdn.net/weixin_42940307/article/details/141465207  浏览:    关键词:Django对RawQuerySet进行计数

提问

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

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

这是我的查询

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 )

然后它的返回值是

Car_Deferred_model_id_user_id object

大家有什么想法吗?

回答1

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com