MongoDB教程
MongoDB运算符
MongoDB命令
MongoDB数据库
MongoDB Shell
MongoDB云和工具

MongoDB 游标方法

MongoDB游标方法修改了指定查询的执行方式。以下是带有说明,语法和示例的游标方法的列表。

#1 cursor.addOption(flag)

该方法添加了" OP_QUERY"连线协议标志。添加它是为了更改可查询标志之类的查询行为。
示例
var t = db.myCappedCollection;
var cursor = t.find().
addOption(DBQuery.Option.tailable)
.addOption(DBQuery.Option.awaitData)
上面的示例添加了tailable标志和awaitData标志,以确保查询返回可尾游标。使用此方法将生成一个游标,该游标在返回完整的结果集后等待几秒钟。这样,在查询过程中就可以获取并返回其他数据。

#2、 Cursor.batchSize(size)

MongoDB 对象的批处理结果返回的文档数量使用批量大小方法指定。在许多情况下,如果我们修改批处理大小,将不会影响用户或应用程序。
示例
db.inventory.find().batchSize(10)

MongoDB游标方法

#3、 cursor.close()

该方法用于关闭游标并根据该方法的指令释放相关的服务器资源。服务器将自动关闭游标,其剩余结果为零或闲置了指定时间。
示例
db.collection.find(<query>).close()

#4、 cursor.collat​​ion( )

MongoDB collat​​ion()方法指定db.collection.find()返回的游标的排序规则。
被close方法接受:
{
   locale: <string>,
   caseLevel: <boolean>,
   caseFirst: <string>,
   strength: <int>,
   numericOrdering: <boolean>,
   alternate: <string>,
   maxVariable: <string>,
   backwards: <boolean>
}
示例:
db.lidihuo.find( { x: "a" } ).collation( { locale: "en_US", strength: 1 } )
输出:
MongoDB游标方法

#5、 cursor.forEach(function)

JavaScript函数将使用forEach方法将游标应用于所有文档。
语法:
db.collection.find().forEach(<function>)
示例:
在find()方法返回的光标上调用forEach()方法以显示集合中所有用户的名称:
db.users.find().forEach( function(lidihuo) { print( "user: " + editors.name ); } );
输出:
MongoDB游标方法

#6、 cursor.hint(index)

在查询期间调用该方法,以覆盖MongoDB的默认索引选择和查询优化过程。
示例:
将使用以下查询返回用户集合中使用年龄字段索引的所有文档。
db.users.find().hint( { age: 1 } )

#7、 cursor.limit()

此方法用于指定光标返回的最大文档数。它将在游标内使用,并且与SQL数据库中的LIMIT语句相当。
示例:
db.collection.find(<query>).limit(<number>)

#8、 cursor.map(function)

map方法供光标访问的文档使用,并且还将最近的应用程序的返回值收集到数组中。
示例:
db.users.find().map( function(u) { return u.name; } );

#9、 cursor.max()

max方法用于限制find()。max()方法的结果。 MongoDB为特定索引指定排他上限,从而为复合键索引指定上限。
示例
为集合创建以下索引:
db.products.createIndexes( [
   { "item" : 1, "type" : 1 },
   { "item" : 1, "type" : -1 },
   { "price" : 1 }])
如果使用的顺序是{item: 1,type: 1}索引,则max()限制对等于item等于Mango且类型等于
的文档的查询
db.products.find().max( { item: 'Mango', type: 'Alfonso' } ).hint( { item: 1, type: 1 } )

#10、 cursor.min()

要限制find()的结果。 min()MongoDB按顺序指定特定索引的下限。此方法提供了一种定义复合键索引下限的方法。
语法:
{ field1: <min value>, field2: <min value2>, fieldN:<min valueN> }
示例:
首先,创建一个名为superstore的示例集合,其中包含以下文档:
db.products.insertMany([
{ "_id" : 1, "item" : "Java", "type" : "book", "price" : NumberDecimal("1.09") },
{ "_id" : 2, "item" : "MongoDB", "type" : "book", "price" : NumberDecimal("1.9") },
{ "_id" : 3, "item" : "Homefoil","type" : "Utensil", "price" : NumberDecimal("1.2") },
{ "_id" : 4, "item" : "Handwash", "type": "Utensil", "price" : NumberDecimal("1.29") },
{ "_id" : 5, "item" : "Rice", "type" : "Grocery", "price" : NumberDecimal("1.59") },
{ "_id" : 6, "item" : "Mango", "type" : "Fruit", "price" : NumberDecimal("1.29") },
{ "_id" : 7, "item" : "Orange", "type" : "Fruit", "price" : NumberDecimal("2.99") },
{ "_id" : 9, "item" : "Apple", "type" : "Fruit", "price" : NumberDecimal("1.99") },
{ "_id" : 8, "item" : "Potato", "type" : "vegetable", "price" : NumberDecimal("0.99") },
{ "_id" : 10, "item" : "Onion", "type" : "vegetable", "price" : NumberDecimal("1.39") }
])
现在,为集合创建索引:
MongoDB游标方法
最小()方法使用{item: 1,type: 1}索引的顺序将查询限制为文档。
db.products.find().min( { item: 'Java', type: 'book' } ).hint( { item: 1, type: 1 } )

#11、 cursor.tailable()

tailable方法将光标标记为可尾。它可作为封顶馆藏的扫描仪。即使到达集合的最后一个节点,它也保持打开状态。该方法的应用程序将作为新数据插入集合中而继续运行。
语法:
cursor.tailable( { awaitData : <boolean> } )
如果将awaitdata标志设置为true,则当游标等待上限数据的结尾到达等待新数据到达时,MongoDB将在一段时间内阻塞查询线程。当将新数据插入上限集合中时,发出阻塞线程的信号,将其唤醒并返回下一批到客户端。

#12、 cursor.toArray()

该方法返回一个数组,该数组具有所有属于游标的文档。它将所有文档加载到RAM中,并通过完全迭代光标来耗尽光标。
示例:
var allProductsArray = db.products.find().toArray();
if (allProductsArray.length > 0) { printjson (allProductsArray[0]); }

昵称: 邮箱:
Copyright © 2022 立地货 All Rights Reserved.
备案号:京ICP备14037608号-4