Is it possible to do multiple orderBy() columns?
knex
.select()
.table(\'products\')
.orderBy(\'id\', \'asc\')
The orderBy() chainable on
The original answer is technically correct, and useful, but my intention was to find a way to programatically apply the orderBy()
function multiple times, here is the actual solution I went with for reference:
var sortArray = [
{'field': 'title', 'direction': 'asc'},
{'field': 'id', 'direction': 'desc'}
];
knex
.select()
.table('products')
.modify(function(queryBuilder) {
_.each(sortArray, function(sort) {
queryBuilder.orderBy(sort.field, sort.direction);
});
})
Knex offers a modify function which allows the queryBuilder to be operated on directly. An array iterator then calls orderBy()
multiple times.