Parse query as Sequelize.
npm i @axolo/query2sequelize
const query2sequelize = require('@axolo/query2sequelize')
const result = query2sequelize({
name: '', // config.keepEmpty = false
price: '>99',
name: 'Da,Fang',
title: '%Sample%',
birthDate: 'null',
gender: '!null',
'role.name': 'admin',
access_token: 'secret',
additionalField: 'value',
_include: 'users,orders',
_order: 'createdAt,!updatedAt'
_offset: 10,
_limit: 20
})
result
{
access_token: 'secret',
include: ['users', 'orders'],
where: {
price: { [Sequelize.Op.gt]: '99' },
name: { [Sequelize.Op.in]: ['Da', 'Fang'] },
title: { [Sequelize.Op.like]: '%Sample%' },
birthDate: { [Sequelize.Op.is]: null },
gender: { [Sequelize.Op.not]: null },
'$role.name$': 'admin',
additionalField: 'value'
},
order: [
['createdAt', 'asc'],
['updatedAt', 'desc']
],
offset: 10,
limit: 20
}
query2sequelize(query, [config])
params | sql | example | description |
---|---|---|---|
_include |
LEFT OUTER JOIN |
_include=user,newsTags |
join user and newsTags |
news hasOne user, hasMany tags
-- curl '/news?_include=user,tags'
SELECT * FROM news
LEFT OUTER JOIN `user` ON `user`.id = news.userId
LEFT OUTER JOIN newsTag ON newsTag.newsId = news.id;
params | sql | example | description |
---|---|---|---|
= |
price=99 |
price = 99 | |
> |
> |
price=>99 |
price > 99 |
< |
< |
price=<100 |
price < 100 |
! |
!= |
price=!99 |
price != 99 |
!< |
>= |
price=!<100 |
price >= 100 |
!> |
<= |
price=!>99 |
price <= 100 |
% |
LIKE |
title=Hangzhou% |
starts with 'Hangzhou' |
, |
IN |
name=zhangsan,lisi |
name in ['zhangsan', 'lisi'] |
~ |
BETWEEN AND |
date=2023-07-01~2023-08-01 |
date in july of 2023 |
!null |
IS NOT NULL |
gender=!null |
gender is not null |
null |
IS NULL |
gender=null |
gender is null |
news of October 2024
-- curl '/news?createdAt=2024-10-01~2024-11-01'
SELECT * FROM news
WHERE createdAt BETWEEN '2024-10-01' AND '2024-11-01';
params | sql | example | description |
---|---|---|---|
_order |
ORDER BY |
_order=updatedAt |
order by updatedAt asc |
! |
DESC |
_order=!updatedAt |
order by updatedAt desc |
, |
, |
_order=sort,!updatedAt |
sort asc, updatedAt desc |
get news with top and updatedAt desc
-- curl '/news?_order=top,!updatedAt'
SELECT * FROM news
ORDER BY `top` ASC, updatedAt DESC;
params | sql | example | description |
---|---|---|---|
_offset |
LIMIT |
_offset=10 |
record start from 10 |
_limit |
LIMIT |
_limit=20 |
limit 20 records |
news of page 2
-- curl '/news?_offset=10&_limit=20'
SELECT * FROM news
LIMIT 10, 20;
params | type | default | description |
---|---|---|---|
Sequelize |
Object |
config.Sequelize |
Sequelize instance |
offset |
Number |
0 |
default offset |
limit |
Number |
1000 |
default limit |
reservedKeys |
Array |
['access_token'] |
keys not be parsed to where |
keepEmpty |
Boolean |
false |
keep empty string query, like name= |
Yueming Fang 2024-12-05