首页 > 解决方案 > 在 MongoDB 中按 INC 值查找文档

问题描述

从我的网站客户端,我向后端 Node.js 服务器发送 API 请求,并通过 ID 查找特定文档,如下所示:

var ObjectID = require('mongodb').ObjectID;   

db.collection('users').find({"_id": new ObjectID(req.body._id)})

其中req.body._id等于整个 ID 字符串,例如'5d0381ad681a2a3aa1dc5872'

但是我宁愿只发送字符串的INC(不断递增的值)部分作为参数:'c5872'

我应该如何仅根据 INC 值查找特定文档?(我假设 INC 是独一无二的)

任何帮助是极大的赞赏。

标签: node.jsmongodbexpressmongoose

解决方案


您可以在字符串中临时转换您的 _id 以便能够使用正则表达式:

db.users.aggregate([
  {
    $addFields: { id: { $toString: '$_id' } }
  },
  {
    $match: { id: /c5872$/ }
  }
])

更简洁的解决方案是直接使用子字符串创建字段,以避免使用正则表达式:

db.users.aggregate([
  {
    $addFields: { id: { $substr: [{ $toString: '$_id' }, 19, 24] } }
  },
  {
    $match: { id: 'c5872' }
  }
])

https://docs.mongodb.com/manual/reference/operator/aggregation/addFields/ https://docs.mongodb.com/manual/reference/operator/aggregation/substr/


推荐阅读