如何限制从 MongoDB 查询中的字段返回的字符数量?


对此,可以使用 MongoDB $substr。我们首先使用文档创建集合 −

> dblimitTheNumberOfCharactersDemoinsertOne({"Title":"MongoDB is No SQL database"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cf23013b64a577be5a2bc0e")
}
> dblimitTheNumberOfCharactersDemoinsertOne({"Title":"MySQL is a relational database"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5cf2302db64a577be5a2bc0f")
}

以下是使用 find() 方法显示集合中所有文档的查询 −

> dblimitTheNumberOfCharactersDemofind()pretty();

这将生成如下文档 −

{
   "_id" : ObjectId("5cf23013b64a577be5a2bc0e"),
   "Title" : "MongoDB is No SQL database"
}
{
   "_id" : ObjectId("5cf2302db64a577be5a2bc0f"),
   "Title" : "MySQL is a relational database"
}

以下是限制从 MongoDB 查询中的某个字段返回的字符数量的查询 −

> dblimitTheNumberOfCharactersDemoaggregate(
   [
      {
         $project:
         {
            Characters: { $substr: [ "$Title", 0, 20 ] }
         }
      }
   ] 
);

这将生成如下文档 −

{ "_id" : ObjectId("5cf23013b64a577be5a2bc0e"), "Characters" : "MongoDB is No SQL da" }
{ "_id" : ObjectId("5cf2302db64a577be5a2bc0f"), "Characters" : "MySQL is a relationa" }

更新日期: 30-Jul-2019

117 次浏览

开启您的 职业

通过完成课程获得认证

开始
广告