Ruby操作MongoDB(进阶九)-批量操作Bulk Operations

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Ruby操作MongoDB(进阶九)-批量操作Bulk Operations相关的知识,希望对你有一定的参考价值。

   本篇文章主要讲解批量操作的相关知识。主要会讲解下面的方法的使用insert_one,insert_many,delete_one,delete_many,replace_one,update_one,update_many七个方法。

   批量写入的API在一次方法调用中会想服务器发送一个操作的列表。如果你设定了ordered参数,就可以确保你传递的操作的执行顺序。

   批量写方法有三个参数:第一是一个操作列表,第二是boolean类型的ordered参数,默认值是true;第三个是写相关参数,默认为集合写相关。

   下面展示的是有效的写操作:

  1. insert_one方法

{:insert_one=>{:x=>1}}

2. insert_many方法

{:insert_many=>[{:x=>1},{:x=>2}]}

3. delete_one方法

{:delete_one=>{:filter=>{:x=>1}}}

4. delete_many方法

{:delete_many=>{:filter=>{:x=>1}}}

5. replace_one方法

{:replace_one=>{:filter=>{:x=>1}},
                :replacement={:x=>2},
                :upsert=>true #可选参数,默认为false
                }

6. update_one方法

{:update_one=>{:filter=>{:x=>1},
               :update=>{‘$set‘=>{:x=>2}},
               :upsert=>true}}

7. update_many方法

{:update_many=>{:filter=>{:x=>1},
               :update=>{‘$set‘=>{:x=>2}},
               :upsert=>true}}

下面的实例展示的是如何将操作传递到批量写入方法中

coll=client[‘documents‘]
coll.bulk_write([{:insert_one=>{:x=>1}},
                 {:update_one=>{:filter=>{:x=>1},
                                :update=>{‘$set‘=>{:x=>2}}}
                 },
                 {:replace_one=>{:filter=>{:x=>2},
                                 :replacement=>{:x=>3}
                                 }}
               
              ],:order=>true)

批量操作的学习到此结束

本文出自 “techFuture” 博客,谢绝转载!

以上是关于Ruby操作MongoDB(进阶九)-批量操作Bulk Operations的主要内容,如果未能解决你的问题,请参考以下文章

Ruby操作MongoDB(进阶八)-聚合操作Aggregation

Ruby操作MongoDB(进阶五)-数据库管理Administration

Ruby操作MongoDB(进阶十)--文本搜索text search

Ruby操作MongoDB数据库(进阶十二)--GridFS

Ruby操作MongoDB(进阶六)-索引Indexing

Ruby操作MongoDB(进阶十一)--空间信息搜索Geospatial Search