Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ionic-framework/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Django通过外键进行排序_Python_Django_Django Queryset - Fatal编程技术网

Python Django通过外键进行排序

Python Django通过外键进行排序,python,django,django-queryset,Python,Django,Django Queryset,我有一个模型,可以连接到两个模型之一。我将其设置为: class Example(models.Model): foo_flag = models.BooleanField(default=False) foo = models.ForeignKey(Foo) bar_flag = models.BooleanField(default=False) bar = models.ForeignKey(Bar) 现在,Foo和Bar都创建了一个名为date\u的字段

我有一个模型,可以连接到两个模型之一。我将其设置为:

class Example(models.Model):
    foo_flag = models.BooleanField(default=False)
    foo = models.ForeignKey(Foo)
    bar_flag = models.BooleanField(default=False)
    bar = models.ForeignKey(Bar)
现在,
Foo
Bar
都创建了一个名为
date\u的字段,其中包含日期时间。如果我有以下查询集:

queryset = Example.objects.all()

无论外键是哪种型号,我怎样才能让它按创建日期排序?不会
queryset=Example.objects.order\u by('foo\u创建日期','bar\u创建日期')
work?

否,因为这将首先按
foo\uu date\u created
下单,然后按
bar\uu date\u created
下单priority@RyanSaxe你怎么可能在两个字段上排序而不优先排序一个呢?但是,根据你所说的,一个示例只有一个Foo或一个Bar。优先级将相等。@RobL如果您在可为空的列上排序,请记住您将有错误的排序。不设置foo的记录将始终位于顶部(或底部取决于排序顺序),而不考虑bar的值(这是您真正关心的值)。好的,它必须是这样的:
queryset=Example.objects.extra(select={o':'(如果创建的foo\uu日期不为空,则创建的foo\uu日期不为空,则创建的bar\uu日期不为空,则创建的bar\uu日期结束),order\u by='o'}
但创建的
日期
列可能必须包含直通表名称。