postgresql – Sequelize.js:查询不在数组中($ne表示数组中的项)

发布时间:2020-08-10 发布网站:编程之家
编程之家收集整理的这篇文章主要介绍了postgresql – Sequelize.js:查询不在数组中($ne表示数组中的项)编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我希望使用Sequelize从postgres数据库中提取项目,但只返回id与给定数组中的任何项目不相等的项目.

Sequelize documentation中,运算符$ne表示不相等,$in表示返回具有与给定数组匹配的值的属性的项目,但它看起来不像是有一个运算符来组合这两个.

例如,如果我在数据库中使用id [1,2,3,4,5,6],我想通过比较另一个数组(即[2,4])过滤那些项目,这样它就会返回[1,6].在我的例子中,我也随机化了退货订单和限价,但这可以忽略不计.

function quizQuestions(req,res) {
  const query = {
    limit: 10,order: [ [sequelize.fn('RANDOM')] ],where: {
      id: { $ne: [1,3] } // This does not work
    }
  };

  Question.findAll(query)
  .then(results => res.status(200).json(map(results,r => r.dataValues)))
  .catch(err => res.status(500).json(err));
}

编辑:使用@piotrbienias回答,我的查询如下所示:

const query = {
    limit: 10,where: {
      id: { $notIn: [1,3] }
    }
  };

解决方法

$notIn,你一定错过了它.生成$notIn的示例性查询

SELECT "id","name"
FROM "categories" AS "Category"
WHERE "Category"."id" NOT IN (1,2);

编辑

您引用的文档适用于Sequelize的2.0版本,您应该更新到3.0.

总结

以上是编程之家为你收集整理的postgresql – Sequelize.js:查询不在数组中($ne表示数组中的项)全部内容,希望文章能够帮你解决postgresql – Sequelize.js:查询不在数组中($ne表示数组中的项)所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢交流学习经验,点击链接加入编程之家官方QQ群:1065694478
编程之家官方公众号

微信公众号搜索 “ 程序精选 ” ,选择关注!

微信公众号搜索 “ 程序精选 ”
精选程序员所需精品干货内容!