在nodejs中排序findAll排序顺序
我正在尝试通过sequelize从数据库中输出所有对象列表,如下所示,并希望在我在where子句中添加id时对数据进行整理。
exports.getStaticCompanies = function () { return Company.findAll({
where: {
id: [46128, 2865, 49569, 1488, 45600, 61991, 1418, 61919, 53326, 61680]
},
attributes: ['id', 'logo_version', 'logo_content_type', 'name', 'updated_at']
});
};
但是问题是渲染后,所有数据按如下进行整理。
46128, 53326, 2865, 1488, 45600, 61680, 49569, 1418, ....
正如我发现的那样,它既没有按ID也没有按名称排序。请帮我解决。
回答:
在序列化中,您可以轻松添加order by子句。
exports.getStaticCompanies = function () { return Company.findAll({
where: {
id: [46128, 2865, 49569, 1488, 45600, 61991, 1418, 61919, 53326, 61680]
},
// Add order conditions here....
order: [
['id', 'DESC'],
['name', 'ASC'],
],
attributes: ['id', 'logo_version', 'logo_content_type', 'name', 'updated_at']
});
};
看看我如何添加order
对象数组?
order: [ ['COLUMN_NAME_EXAMPLE', 'ASC'], // Sorts by COLUMN_NAME_EXAMPLE in ascending order
],
编辑:
一旦在.then()
诺言中收到对象,您可能必须订购这些对象。查看有关根据自定义顺序对对象数组进行排序的问题:
以上是 在nodejs中排序findAll排序顺序 的全部内容, 来源链接: utcz.com/qa/419713.html