Django对RawQuerySet进行计数

打印 上一主题 下一主题

主题 517|帖子 517|积分 1551

提问

你好,我使用的是django 1.2,然后我想知道如何对原生查询集(RawQuerySet)的行进行计数。
惯例的.count()方法行不通。
这是我的查询
  1. 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"
  2. cars = Car.objects.raw(query, [lat, lat, lon, min_price, max_price, miles])
  3. return HttpResponse( cars )
复制代码
然后它的返回值是
  1. Car_Deferred_model_id_user_id object
复制代码
各人有什么想法吗?
回答1

使用’len()'函数,这会带来:
  1. 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"
  2. cars = Car.objects.raw(query, [lat, lat, lon, min_price, max_price, miles])
  3. 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等国外编程内容
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

南飓风

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表