找到 1660 篇文章 关于大数据分析

基于角色的 MongoDB 查询,仅获取“姓名”字段?

AmitDiwan
更新于 2020年5月14日 06:22:55

231 次浏览

为此,使用 aggregate()。在这里,我们考虑了 3 个角色——管理员、访客和用户。让我们创建一个包含文档的集合——> db.demo532.insertOne({"Name":"Chris", "Type":"Admin"});{    "acknowledged" : true,    "insertedId" : ObjectId("5e8b4a9def4dcbee04fbbbf9") } > db.demo532.insertOne({"Name":"David", "Type":"Guest"});{    "acknowledged" : true,    "insertedId" : ObjectId("5e8b4aa3ef4dcbee04fbbbfa") } > db.demo532.insertOne({"Name":"Bob", "Type":"User"});{    "acknowledged" : true,    "insertedId" : ObjectId("5e8b4ab0ef4dcbee04fbbbfb") } 使用 find() 方法显示集合中的所有文档——> db.demo532.find(); 这将产生以下输出——{ "_id" : ObjectId("5e8b4a9def4dcbee04fbbbf9"), "Name" : "Chris", "Type" : "Admin" } { "_id" : ObjectId("5e8b4aa3ef4dcbee04fbbbfa"), "Name" : "David", "Type" : "Guest" } { "_id" ... 阅读更多

如何在 MongoDB 控制台中使用带有特殊字符(如“customer_tracker-990”)的数据库名称?

AmitDiwan
更新于 2020年5月13日 10:25:43

364 次浏览

是的,使用 getSiblingDB()。让我们向数据库添加一些文档——> use customer_tracker-990; switched to db customer_tracker-990 > db.demo1.insertOne({"Name":"Chris"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea4697ca7e81adc6a0b3954") } > db.demo1.insertOne({"Name":"David"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea46980a7e81adc6a0b3955") } > db.demo1.insertOne({"Name":"Bob"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea46984a7e81adc6a0b3956") } 使用 find() 方法显示集合中的所有文档——> db.getSiblingDB("customer_tracker-990").demo1.find(); 这将产生以下输出——{ "_id" : ObjectId("5ea4697ca7e81adc6a0b3954"), "Name" : "Chris" } { "_id" : ObjectId("5ea46980a7e81adc6a0b3955"), "Name" : "David" } { "_id" : ObjectId("5ea46984a7e81adc6a0b3956"), "Name" : "Bob" }阅读更多

如何限制 MongoDB 集合中的文档数量?

AmitDiwan
更新于 2020年5月13日 10:24:09

393 次浏览

要限制集合中的文档数量,请设置 capped - true。在此处设置大小。让我们创建一个包含文档的集合——> db.createCollection( "demo683", { capped: true, size: 5 ,max:4} ) { "ok" : 1 } > db.demo683.insertOne({Value:100}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea468afa7e81adc6a0b394e") } > db.demo683.insertOne({Value:500}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea468b0a7e81adc6a0b394f") } > db.demo683.insertOne({Value:1000}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea468b1a7e81adc6a0b3950") } > db.demo683.insertOne({Value:400}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea468b2a7e81adc6a0b3951") } > db.demo683.insertOne({Value:800}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea468b3a7e81adc6a0b3952") } ... 阅读更多

有没有办法跳过 MongoDB 中的一些文档?

AmitDiwan
更新于 2020年5月13日 10:22:17

119 次浏览

是的,您可以使用 MongoDB 中的 skip() 跳过一些文档。使用 limit() 来显示跳过一些文档后要显示多少个文档。让我们创建一个包含文档的集合——> db.demo682.insertOne({FirstName:"John"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea462a804263e90dac94402") } > db.demo682.insertOne({FirstName:"Sam"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea462ac04263e90dac94403") } > db.demo682.insertOne({FirstName:"Bob"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea462af04263e90dac94404") } > db.demo682.insertOne({FirstName:"David"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea462b304263e90dac94405") } > db.demo682.insertOne({FirstName:"Adam"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea462ba04263e90dac94406") } > db.demo682.insertOne({FirstName:"Chris"}); {    "acknowledged" : true,    "insertedId" : ... 阅读更多

从 MongoDB 集合中获取最顶部的文档

AmitDiwan
更新于 2020年5月13日 10:19:35

143 次浏览

要获取最顶部的文档,请将 find() 与 limit() 一起使用。要仅获取单个文档,请考虑使用 limit(1)。让我们创建一个包含文档的集合——> db.demo681.insertOne({_id:101, Name:"Chris"}); { "acknowledged" : true, "insertedId" : 101 } > db.demo681.insertOne({_id:102, Name:"Bob"}); { "acknowledged" : true, "insertedId" : 102 } > db.demo681.insertOne({_id:103, Name:"David"}); { "acknowledged" : true, "insertedId" : 103 } > db.demo681.insertOne({_id:104, Name:"Bob"}); { "acknowledged" : true, "insertedId" : 104 } > db.demo681.insertOne({_id:105, Name:"Sam"}); { "acknowledged" : true, "insertedId" : 105 } 使用 find() 方法显示集合中的所有文档——> db.demo681.find(); 这将产生以下输出——{ ... 阅读更多

在 MongoDB $and 中设置 $gt 条件

AmitDiwan
更新于 2020年5月13日 10:18:33

184 次浏览

$and 对一个或多个表达式的数组执行逻辑 AND 运算。让我们创建一个包含文档的集合——> db.demo680.insertOne({Values:40}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea4461b04263e90dac943fe") } > db.demo680.insertOne({Values:70}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea4461e04263e90dac943ff") } > db.demo680.insertOne({Values:[80, 30]}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea4462a04263e90dac94400") } > db.demo680.insertOne({Values:20}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea4463304263e90dac94401") } 使用 find() 方法显示集合中的所有文档——> db.demo680.find(); 这将产生以下输出——{ "_id" : ObjectId("5ea4461b04263e90dac943fe"), "Values" : 40 } { "_id" : ... 阅读更多

在 MongoDB 中拉取子子数组中的元素?

AmitDiwan
更新于 2020年5月14日 09:25:43

364 次浏览

要拉取元素,请使用 $pull 以及 $(positional) 运算符。让我们创建一个包含文档的集合——> db.demo679.insertOne( ...    { ...       id:1, ...       "details": [ ...          { ...             CountryName:"US", ...             "information": [ ... ...                { "Name": "Chris", "FirstName": "Name=Chris" }, ... ...                {"Name": "Bob", "FirstName": "Name=Bob" } ...             ] ...          }, ... ... 阅读更多

如何为我的集合建立索引以使用复合多键索引?

AmitDiwan
更新于 2020年5月14日 09:24:10

62 次浏览

为此,使用 ensureIndex()。让我们创建一个包含文档的集合 -> db.demo678.ensureIndex({id:1,"details.userId":1}); {    "createdCollectionAutomatically" : true,    "numIndexesBefore" : 1,    "numIndexesAfter" : 2,    "ok" : 1 } > db.demo678.insertOne( ...    { ...       id:101, ... ...       "details" : [ ...          { ...             "userId" : "1001", ...             "userName":"Chris" ...          }, ...          { ...             "userId" : "1002", ...             "userName":"David" ...          } ...       ], ...       "otherDetails" : [ ...          { ...             CountryName:"US", ...             EmailId:["[email protected]","[email protected]"] ...          } ...       ] ...    } ... ); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea4276904263e90dac943fc") }使用 find() 方法显示集合中的所有文档 -> db.demo678.find();这将产生以下输出 ->{ "_id" : ObjectId("5ea4276904263e90dac943fc"), "id" : 101, "details" : [    { "userId" : "1001", "userName" : "Chris" },    { "userId" : "1002", "userName" : "David" } ], "otherDetails" : [    { "CountryName" : "US", "EmailId" : [ "[email protected]", "[email protected]" ] } ] }

MongoDB 查询以对文档中特定字段的值求和

AmitDiwan
更新于 2020年5月13日 10:09:06

234 次浏览

让我们创建一个包含文档的集合 -> db.demo677.insertOne({Value:10}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea421f404263e90dac943f8") } > db.demo677.insertOne({Value:50}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea421f704263e90dac943f9") } > db.demo677.insertOne({Value:20}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea421fa04263e90dac943fa") } > db.demo677.insertOne({Value:20}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea421fe04263e90dac943fb") }使用 find() 方法显示集合中的所有文档 -> db.demo677.find();这将产生以下输出 ->{ "_id" : ObjectId("5ea421f404263e90dac943f8"), "Value" : 10 } { "_id" : ObjectId("5ea421f704263e90dac943f9"), "Value" : 50 } { "_id" : ObjectId("5ea421fa04263e90dac943fa"), "Value" : 20 } { "_id" : ... 阅读更多

MongoDB 分组查询以获取文档中重复分数的计数?

AmitDiwan
更新于 2020年5月13日 10:06:36

168 次浏览

对于分组查询,使用 MongoDB $group 并使用 $sum 获取计数。让我们创建一个包含文档的集合 -> db.demo676.insertOne({"Marks":87}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea41eed04263e90dac943f2") } > db.demo676.insertOne({"Marks":75}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea41ef304263e90dac943f3") } > db.demo676.insertOne({"Marks":87}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea41ef404263e90dac943f4") } > db.demo676.insertOne({"Marks":65}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea41ef704263e90dac943f5") } > db.demo676.insertOne({"Marks":65}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea41ef804263e90dac943f6") }使用 find() 方法显示集合中的所有文档 -> db.demo676.find();这将产生以下输出 ->{ "_id" : ... 阅读更多

广告