Django 或查询

2019-12-29 16:20:48 +08:00
 dolaxi

模型:

class Goods(models.Model):
    name=models.CharField(max_length=50,verbose_name='名称')
    image = models.CharField(max_length=250,verbose_name='封面图')
    is_banner = models.BooleanField(default=False,verbose_name='是否是轮播图')
    nav = models.ForeignKey('Nav',verbose_name='所属分类导航')

视图:

class HomeView(request):
    banner_queryset=Goods.objects.filter(is_banner=1)[:3]    #首页 3 条轮播图数据
    clothes_queryset=Goods.objects.filter(nav_id=1)[:5]        #首页 5 条衣服数据

这两个查询语句,合成一个查询语句,如何写?

banner_queryset 、clothes_queryset 这两个查询出的结果,有些数据可能是重合的

1356 次点击
所在节点    问与答
9 条回复
uhian
2019-12-29 18:52:18 +08:00
没有切片的可以 result = queryset1 | queryset2
有切片操作的貌似不能这样
实在不行将 clothes_queryset 加一个 exclude(id__in=[b.id for b in banner_queryset])?
SingeeKing
2019-12-29 18:56:02 +08:00
搜索关键字:Django F
SingeeKing
2019-12-29 18:56:19 +08:00
哦不,是 Django Q🌚
uhian
2019-12-29 18:59:28 +08:00
@SingeeKing Q 也不能切片啊
SingeeKing
2019-12-29 19:08:53 +08:00
@uhian #4 他的切片可以直接用 limit 啊。。
uhian
2019-12-29 19:31:56 +08:00
@SingeeKing 切片不就是 LIMIT 么?还有别的操作?
SingeeKing
2019-12-29 20:03:40 +08:00
@uhian #6 Django 竟然不能直接 Limit……

搜了一下官方的说法,https://groups.google.com/forum/#!topic/django-users/Q4KB5qPlGtA 似乎没办法直接合
uhian
2019-12-29 20:15:19 +08:00
@SingeeKing Django 的切片,也就是[:3],实际做数据查询也就是转成 SQL 就是 limit。
Django 的 LIMIT 没啥问题,问题是两个带 LIMIT 的查询结果( QuerySet )直接求或,貌似是真不行。查询结果本身可以求或,还可以返回 distinct 结果。
dolaxi
2019-12-29 21:43:28 +08:00
@SingeeKing @uhian
有切片确实不好操作,
result = queryset1 | queryset2 我试了一下,貌似可以成功,看原生查询语句,好像没啥毛病

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/633326

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX