在数据编织中保留数据库输出排序



我有一个要求,其中数据编织输出应按特定顺序排列。

这是我必须处理的数据库输出

[
{
"order": "Order 2",
"inv": 6150579.00000,
"dio": 31,
"week": "2020-06-01T00:00:00"
},
{
"order": "Order 2",
"inv": 6318049.21000,
"dio": 33,
"week": "2020-06-08T00:00:00"
},
{
"order": "Order 1",
"inv": 6306077.76000,
"dio": 45,
"week": "2020-06-01T00:00:00"
},
{
"order": "Order 1",
"inv": 6047050.75000,
"dio": 43,
"week": "2020-06-08T00:00:00"
},
]

在数据库查询中,我编写了条件,以便使用特定的订单条件对其进行排序。例如,在这种情况下,订单"12345 - 订单 1"必须在输出中排在第一位。

但是当我使用 groupBy 条件转换数据编织中的输出时,排序顺序发生了变化

payload map {
"order" : $.order,
"inv" : $.inv,
"dio" : $.dio,
"week" : $.week
} groupBy $.order

输出:

{
"Order 1": [
{
"order": "Order 1",
"inv": 6306077.76000,
"dio": 45,
"week": "2020-06-01T00:00:00"
},
{
"order": "Order 1",
"inv": 6047050.75000,
"dio": 43,
"week": "2020-06-08T00:00:00"
}
],
"Order 2": [
{
"order": "Order 2",
"inv": 6150579.00000,
"dio": 31,
"week": "2020-06-01T00:00:00"
},
{
"order": "Order 2",
"inv": 6318049.21000,
"dio": 33,
"week": "2020-06-08T00:00:00"
}
]
}

您会看到订单 1 值排在第一位。

这是我编造的一个例子。实际上我有数百个数据。 在这种情况下,按$$$放置订单也是错误的。

groupBy(( 不保证任何排序。如果未明确提及,则不应假定任何操作将保留顺序。您必须显式排序输出:

%dw 2.0
output application/json
---
payload map {
"order" : $.order,
"inv" : $.inv,
"dio" : $.dio,
"week" : $.week
} groupBy $.order 
mapObject (($$): $ orderBy -$.inv ) // order inside each group by inv descending order
orderBy $$ // order the groups by key

更新:根据评论,我更改了脚本以相反的顺序按inv属性对每个组进行排序。

更新 2:我还按键对每个组进行排序,因此"订单 1"高于"订单 2"。

输出:

{
"Order 1": [
{
"order": "Order 1",
"inv": 6306077.76000,
"dio": 45,
"week": "2020-06-01T00:00:00"
},
{
"order": "Order 1",
"inv": 6047050.75000,
"dio": 43,
"week": "2020-06-08T00:00:00"
}
],
"Order 2": [
{
"order": "Order 2",
"inv": 6318049.21000,
"dio": 33,
"week": "2020-06-08T00:00:00"
},
{
"order": "Order 2",
"inv": 6150579.00000,
"dio": 31,
"week": "2020-06-01T00:00:00"
}
]
}