默认orderby列类型为date时的网格排序错误。其他人有这个问题吗?

问题描述 投票:0回答:1

我有这个动作

@auth.requires(auth.has_membership(CHECKER_ROLE) or auth.has_membership(SUPERVISOR_ROLE))
def list_tags_to_issue():
    """List tags to issue.

    :return: Dict with grid.
    """

   query = ((db.wo.is_active == True)
            & (db.wo.tags_issued == False)
            & (db.wo.pies_verified == False)
            & (db.wo.equipment_id == db.equipment.id))

    grid = SQLFORM.grid(
        query,
        create=False,
        csv=False,
        deletable=False,
        details=False,
        editable=False,
        fields=[db.wo.est_finish,
                db.equipment.name,
                db.wo.sn,
                db.wo.opts,
                db.wo.finished,  # Necessary dummy entry.
                db.wo.canceled_on,  # Necessary dummy entry.
                db.wo.canceled_by,  # Necessary dummy entry.
                db.wo.cancel_approved_by,  # Necessary dummy entry.
        ],
        orderby=db.wo.est_finish,
    )

    return dict(grid=grid)

有了这个观点

{{extend 'layout.html'}}

<h2>{{=T('List tags to issue')}}</h2>

{{=grid}}

{{if DEV:
=response.toolbar()
pass}}

如果我尝试更改默认orderby列(est_finish)中的排序,则不会发生。 URL从... orderby = do.wo.est_finish更改为... orderby = ~db.wo.est_finish,但网格不会更改。当我看到db stats时,SQL命令也没有改变。 SQL命令始终是

SELECT "wo"."est_finish", "equipment"."name", "wo"."sn", "wo"."opts", "wo"."finished", "wo"."canceled_on", "wo"."canceled_by", "wo"."cancel_approved_by", "wo"."id" 
FROM "wo", "equipment" 
WHERE (((("wo"."is_active" = 'T') AND ("wo"."tags_issued" = 'F')) AND ("wo"."pies_verified" = 'F')) AND ("wo"."equipment_id" = "equipment"."id")) 
ORDER BY "wo"."est_finish", "wo"."id" LIMIT 20 OFFSET 0;

无论URL从... orderby = do.wo.est_finish更改为... orderby = ~db.wo.est_finish。

这是显示此问题的3个不同视图之一(所有视图共同具有日期列的orderby)。所有其他人工作正常。

如果我从网格中删除orderby参数或将其更改为非日期参数,则一切正常,包括日期列的排序。

有任何想法吗?

谢谢,

JM

web2py
1个回答
0
投票

在web2py组中报告此问题后,它在版本2.18.5中得到修复。

© www.soinside.com 2019 - 2024. All rights reserved.