栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

有没有一种方法可以使用额外的属性来扩展django QuerySet?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

有没有一种方法可以使用额外的属性来扩展django QuerySet?

出现错误是因为qs.reverse()产生了一个新的QuerySet实例,因此您没有反转旧的实例。

如果要采取行动的基本QS,可以执行以下操作:

>>> augmented_books = Book.objects.extra(select={'price': 2))>>> augmented_books[0].price2>>> augmented_books_rev = augmented_books.reverse()>>> augmented_books_rev[0].price2

当然,

select
关键字可能要复杂得多,实际上,它几乎可以是任何适用于
[XXX]
in的有意义的SQL代码段

SELECT ..., [XXX] as price, ... FROM ... WHERe ... (etc)

编辑

正如其他回应所指出的那样,该解决方案 可能 效率不高。

如果确定要从查询中获取 所有 Book对象,则最好进行一个查询,将其存储在列表中,并最终反转结果列表。

另一方面,如果要获取表的“ head”和“ queue”,则进行两次查询会更好,因为您不会查询所有“中间”无用的对象。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/667995.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号