我试图通过迄今为止运行的列来订购我的收集结果,但是我希望分类不敏感。我已经浏览了书架文档,并在这里和其他论坛上搜索无济于事。是否需要一些原始的knex插入?非常感谢任何帮助。
这是我的代码:
new Recipes().query('orderBy', 'name', 'asc').fetch({
withRelated: [
{ instructions: (query) => { query.orderBy('step_number'); }},
'tags',
'ingredients',
'ingredients.alternatives',
'ingredients.tags'
]
});
我想做类似的事情:
new Recipes().query('orderByIgnoreCase', 'name', 'asc').fetch({
withRelated: [
{ instructions: (query) => { query.orderBy('step_number'); }},
'tags',
'ingredients',
'ingredients.alternatives',
'ingredients.tags'
]
});
或:
new Recipes().query('orderBy', LOWER('name'), 'asc').fetch({
withRelated: [
{ instructions: (query) => { query.orderBy('step_number'); }},
'tags',
'ingredients',
'ingredients.alternatives',
'ingredients.tags'
]
});
请在下面尝试
Recipes.query(function (qb) {
qb.orderByRaw('LOWER(name) asc');
})
.fetchAll({
withRelated: [{
'instructions': (query) => query.orderBy('step_number'),
'tags',
'ingredients',
'ingredients.alternatives',
'ingredients.tags'
}]
})
也值得注意的是,PostgreSQL排序取决于OS