Sequelize Where statement with date

前端 未结 4 1900
野的像风
野的像风 2020-12-14 14:01

I am using sequelize as my backend ORM. Now i wish to do some where operations on a Date.

More Speceficly i want to get all data where a date is from now and 7 days

相关标签:
4条回答
  • 2020-12-14 14:28

    You can also use Sequelize.literal() to perform dates manipulation in SQL.

    The following code works with Postgres, but I'm quite sure something similar could be done in other systems as well:

    model.findAll({
      where: {
        start_datetime: {
          $gte: Sequelize.literal('NOW() - INTERVAL "7d"'),
        }
      }
    })
    
    
    0 讨论(0)
  • 2020-12-14 14:31

    This solution is without the moment.js library.

    Between 7 days ago and now

    const sevenDaysAgo = new Date(new Date().setDate(new Date().getDate() - 7));
    models.instagram.findAll({
      where: {
        my_date: {
          $gt: sevenDaysAgo,
          $lt: new Date(),
        },
      },
    });
    

    Between now and 7 from now

    const sevenDaysFromNow = new Date(new Date().setDate(new Date().getDate() + 7));
    models.instagram.findAll({
      where: {
        my_date: {
          $gt: new Date(),
          $lt: sevenDaysFromNow,
        },
      },
    });
    

    Notes:

    • $gt stands for "greater than". You could use $gte instead of $gt. $gte stands for "greater than or equal to". Same for $lte of course.
    • Technically speaking, you need both $lt and $gt to make sure that the date isn't into the future (per the original question).
    • Other answers show the use of [Sequelize.Op.gt] instead of $gt. Use that if on Sequelize v5.
    0 讨论(0)
  • 2020-12-14 14:33

    Just like Molda says, you can use $gt, $lt, $gte or $lte with a date:

    model.findAll({
      where: {
        start_datetime: {
          $gte: moment().subtract(7, 'days').toDate()
        }
      }
    })
    

    If you're using v5 of Sequelize, you've to include Op because the key was moved into Symbol

    const { Op } = require('sequelize')
    
    model.findAll({
      where: {
        start_datetime: {
          [Op.gte]: moment().subtract(7, 'days').toDate()
        }
      }
    })
    

    See more sequelize documentation here

    0 讨论(0)
  • 2020-12-14 14:36

    I had to import the Operators symbols from sequelize and use like so.

    const { Op } = require('sequelize')
    
    model.findAll({
      where: {
        start_datetime: {
          [Op.gte]: moment().subtract(7, 'days').toDate()
        }
      }
    })
    

    According to the docs, for security reasons this is considered best practise.

    See http://docs.sequelizejs.com/manual/tutorial/querying.html for more info.

    Using Sequelize without any aliases improves security. Some frameworks automatically parse user input into js objects and if you fail to sanitize your input it might be possible to inject an Object with string operators to Sequelize.

    (...)

    For better security it is highly advised to use Sequelize.Op and not depend on any string alias at all. You can limit alias your application will need by setting operatorsAliases option, remember to sanitize user input especially when you are directly passing them to Sequelize methods.

    0 讨论(0)
提交回复
热议问题