Skip to content

axolo/query2sequelize

Repository files navigation

query2sequelize

Parse query as Sequelize.

install

npm i @axolo/query2sequelize

usage

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
}

api

query2sequelize(query, [config])

query

include

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;

where

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';

order

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;

limit

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;

config

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

About

Parse query as Sequelize.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published