Sequelize 中使用 Op 的过滤查询汇总指南!最全面!

1. 简介

Sequelize 是一个基于 Node.js 的 ORM 框架,支持多种数据库。Op(Operators)是其提供的查询操作符,用于构建复杂的过滤条件。通过 Op 可以实现 WHERE 子句中的逻辑比较、模糊查询、范围查询等操作。

提示 :使用 Op 前需从 Sequelize 实例引入

javascript 复制代码
const { Op } = require('sequelize');

2. 常用 Op 操作符及示例

2.1 基础比较操作符

操作符 描述 示例代码
Op.eq 等于 { age: { [Op.eq]: 25 } }WHERE age = 25
Op.ne 不等于 { status: { [Op.ne]: 'pending' } }WHERE status != 'pending'
Op.gt 大于 { age: { [Op.gt]: 18 } }WHERE age > 18
Op.gte 大于等于 { price: { [Op.gte]: 100 } }WHERE price >= 100
Op.lt 小于 { age: { [Op.lt]: 30 } }WHERE age < 30
Op.lte 小于等于 { stock: { [Op.lte]: 0 } }WHERE stock <= 0

示例代码:

javascript 复制代码
const users = await User.findAll({
  where: {
    age: {
      [Op.gt]: 18,
      [Op.lt]: 30
    }
  }
});
// 查询年龄在 18~30 之间的用户

2.2 范围查询

操作符 描述 示例代码
Op.between 在范围内 { age: { [Op.between]: [20, 30] } }WHERE age BETWEEN 20 AND 30
Op.notBetween 不在范围内 { price: { [Op.notBetween]: [50, 100] } }
Op.in 在数组中 { id: { [Op.in]: [1, 2, 3] } }WHERE id IN (1, 2, 3)
Op.notIn 不在数组中 { role: { [Op.notIn]: ['admin', 'root'] } }

示例代码:

javascript 复制代码
// 查询状态为 'active' 或 'verified' 的用户
const users = await User.findAll({
  where: {
    status: {
      [Op.in]: ['active', 'verified']
    }
  }
});

2.3 模糊查询

操作符 描述 示例代码
Op.like 区分大小写的模糊匹配 { name: { [Op.like]: '%john%' } }WHERE name LIKE '%john%'
Op.notLike 排除模糊匹配 { title: { [Op.notLike]: '%test%' } }
Op.iLike 不区分大小写的模糊匹配 (PostgreSQL) { email: { [Op.iLike]: '%EXAMPLE.COM' } }
Op.startsWith 以字符串开头 { name: { [Op.startsWith]: 'Alex' } }WHERE name LIKE 'Alex%'
Op.endsWith 以字符串结尾 { path: { [Op.endsWith]: '.jpg' } }WHERE path LIKE '%.jpg'
Op.substring 包含字符串(同 Op.like + %%) { description: { [Op.substring]: 'urgent' } }

示例代码:

javascript 复制代码
// 查询名字以 'A' 开头、包含 'dmin' 的用户(不区分大小写)
const admins = await User.findAll({
  where: {
    [Op.and]: [
      { name: { [Op.startsWith]: 'A' } },
      { role: { [Op.iLike]: '%dmin%' } }
    ]
  }
});

2.4 逻辑操作符

操作符 描述 示例代码
Op.and 逻辑与 { [Op.and]: [{ a: 5 }, { b: 6 }] }WHERE (a = 5 AND b = 6)
Op.or 逻辑或 { [Op.or]: [{ age: 18 }, { isAdult: true }] }
Op.not 逻辑非 { [Op.not]: { role: 'guest' } }WHERE NOT (role = 'guest')

示例代码:

javascript 复制代码
// 查询年龄大于 30 或状态为 'inactive' 的用户
const filteredUsers = await User.findAll({
  where: {
    [Op.or]: [
      { age: { [Op.gt]: 30 } },
      { status: 'inactive' }
    ]
  }
});

2.5 其他操作符

操作符 描述 示例代码
Op.is 是否为 NULL { deletedAt: { [Op.is]: null } }WHERE deletedAt IS NULL
Op.notNull 不为 NULL { email: { [Op.notNull]: true } }WHERE email IS NOT NULL
Op.any 匹配数组中的任意值 (PostgreSQL) { id: { [Op.any]: [1, 2, 3] } }WHERE id = ANY (ARRAY[1,2,3])
Op.col 跨列比较 { where: { amount: { [Op.gt]: Sequelize.col('price') } } }

示例代码:

javascript 复制代码
// 查询未删除的用户
const activeUsers = await User.findAll({
  where: {
    deletedAt: { [Op.is]: null }
  }
});

3. 综合示例

javascript 复制代码
const { Op } = require('sequelize');

// 查询年龄在 20-30 之间、状态为 active 或 verified,且邮箱不为空的用户
const results = await User.findAll({
  where: {
    [Op.and]: [
      { age: { [Op.between]: [20, 30] } },
      { 
        [Op.or]: [
          { status: 'active' },
          { status: 'verified' }
        ]
      },
      { email: { [Op.notNull]: true } }
    ]
  }
});
相关推荐
专业系统开发老赵1 小时前
[特殊字符]《多商户家政系统技术解析:SpringBoot+MyBatisPlus+UniApp高效实战指南》
spring boot·后端·uni-app
鱼樱前端2 小时前
阿里巴巴 Druid、C3P0、DBCP 连接池深度对比与实战指南
java·后端
自珍JAVA2 小时前
正则表达式
后端
Asthenia04122 小时前
深入SpringBoot启动流程:自动配置与Bean生命周期核心解析
后端
豌豆花下猫2 小时前
Python 潮流周刊#95:像人类一样使用计算机(摘要)
后端·python·ai
henujolly2 小时前
node.js学习
node.js
王达舒19943 小时前
Spring Boot中定时任务Cron表达式的终极指南
java·spring boot·后端
demonlg01123 小时前
Go 语言标准库中Channels,Goroutines详细功能介绍与示例
开发语言·后端·golang
王强你强3 小时前
Spring Boot 启动参数终极解析:如何优雅地控制你的应用?
java·spring boot·后端
vener_3 小时前
基于Flask的通用登录注册模块,并代理跳转到目标网址
后端·python·flask