文章目录
聚合框架是MongoDB的高级查询语言,它允许我们通过转换和合并多个文档中的数据来生成新的单个文档中不存在的信息。
聚合管道操作主要包含下面几个部分:
命令 功能描述 备注
$project 指定输出文档里的字段
$match 选择要处理的文档,与fine()类似
$limit 限制传递给下一步的文档数量
$skip 跳过一定数量的文档
$unwind 扩展数组,为每个数组入口生成一个输出文档
$group 根据key来分组文档
$sort 排序文档
$geoNear 选择某个地理位置附近的的文档
$out 把管道的结果写入某个集合
$redact 控制特定数据的访问
$lookup 多表关联(3.2版本新增)
以下是$lookup的使用
1.主要功能 是将每个输入待处理的文档,经过$lookup 阶段的处理,输出的新文档中会包含一个新生成的数组列(户名可根据需要命名新key的名字 )。数组列存放的数据 是 来自 被Join 集合的适配文档,如果没有,集合为空(即 为[ ])
2.基本语法
{
$lookup:
{
from: <collection to join>,
localField: <field from the input documents>,
foreignField: <field from the documents of the "from" collection>,
as: <output array field>
}
}
3.语法的解释说明

4.注:null = null 此为真
其语法功能类似于下面的伪SQL语句
SELECT *, <output array field>
FROM collection
WHERE <output array field> IN (SELECT *
FROM <collection to join>
WHERE <foreignField>= <collection.localField>);
假设 有 订单集合, 存储的测试数据 如下
其中 item 对应 数据为 商品名称
db.orders.insertMany([
{ "_id" : 1, "item" : "almonds", "price" : 12, "quantity" : 2 },
{ "_id" : 2, "item" : "pecans", "price" : 20, "quantity" : 1 }
,{ "_id" : 3 }
]);
db.inventory.insertMany([
{ "_id" : 1, "sku" : "almonds", description: "product 1", "instock" : 120 },
{ "_id" : 2, "sku" : "bread", description: "product 2", "instock" : 80 },
{ "_id" : 3, "sku" : "cashews", description: "product 3", "instock" : 60 },
{ "_id" : 4, "sku" : "pecans", description: "product 4", "instock" : 70 },
{ "_id" : 5, "sku": null, description: "Incomplete" },
{ "_id" : 6 }
]);
此集合中的 sku 数据等同于订单集合中的商品名称。
在这种模式设计下,如果要查询订单表对应商品的库存情况,应如何写代码呢?
很明显这需要两个集合Join。
接下来就是实际演示我们的关联查询的语句了:
db.orders.aggregate([
{
$lookup:
{
from: "inventory",
localField: "item",
foreignField: "sku",
as: "inventory_docs"
}
}
])
结果:
{ "_id" : 1, "item" : "almonds", "price" : 12, "quantity" : 2, "inventory_docs" : [ { "_id" : 1, "sku" : "almonds", "description" : "product 1", "instock" : 120 } ] }
{ "_id" : 2, "item" : "pecans", "price" : 20, "quantity" : 1, "inventory_docs" : [ { "_id" : 4, "sku" : "pecans", "description" : "product 4", "instock" : 70 } ] }
{ "_id" : 3, "inventory_docs" : [ { "_id" : 5, "sku" : null, "description" : "Incomplete" }, { "_id" : 6 } ] }
那如何实现内连接呢?实际上内连接只是需要过滤空值即可。
db.orders.aggregate([
{
$lookup:
{
from: "inventory",
localField: "item",
foreignField: "sku",
as: "inventory_docs"
}
},
{
$match: { "item":{$ne:null}}
}
])
由于我们查询数据的时候常常不单单是要执行联表,联表常常伴随着过滤条件,那在本案例中怎么处理呢,比如我们不要item为空的,要模糊匹配item为p的数据:
db.orders.aggregate([
{
$match:{item:/p/}
},
{
$lookup:
{
from: "inventory",
localField: "item",
foreignField: "sku",
as: "inventory_docs"
}
}
])
结果:

这是针对RubyonRails3.0.x项目的。我有一个包含供应商数据的“查找”表。当我从其他来源导入数据时,我想检查此表(加入SKU)以获取额外数据。在我的应用程序中为这个表格创建模型对我来说似乎不合适。我的应用程序永远不会更改数据,并且除了我刚才提到的数据查找之外,它不需要任何模型关联。它只是偶尔访问以检查一些信息。访问此表的最佳做法是什么?谢谢。 最佳答案 围绕它创建模型没有坏处,但如果您想避免它,您将不得不将原始SQL查询发送到数据库以作为替代方案取回数据。原始查询:RailsrawSQLexample另一方面,我认为围绕模
我试图实现一组我放在纸上的模型,但遇到了一个问题,我认为最好的解决方法是使用多表继承设置。然而,在谷歌搜索后我发现ActiveRecord不支持MTI......尽管有很多文章展示了如何做到这一点。这让我想知道如果没有实现我是否正确设置了我的模型。所以我的问题是为什么ActiveRecord没有内置对MTI的支持?如果您对我的模型设置“将会”是什么样子感到好奇,我会把它留在下面。classPlayer其中玩家可以是CollegePlayer和ProPlayer之一或两者。或者在另一个例子中......classPerson“人”可以是用户、前玩家和/或教练。
我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多
我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序
我如何从Ruby代码连接到mongodb? 最佳答案 首先,您必须安装MongoDbgem:geminstallmongo然后运行代码:require'rubygems'#notnecessaryforRuby1.9require'mongo'db=Mongo::Connection.new.db("mydb")#ORdb=Mongo::Connection.new("localhost").db("mydb")#ORdb=Mongo::Connection.new("localhost",27017).db("mydb")
我正在尝试使用聚合框架(使用ruby)并像这样投影日期:db['requests'].aggregate([{"$project"=>{_id:0,method:'$method',user:'$user',year:{'$year'=>'$timestamp'}}}])文档是这样的:{_id:ObjectId("5177d7d7df26358289da7dfd"),timestamp:ISODate("2013-04-12T03:58:05+00:00"),method:"POST",status:"200",inputsize:"874",outputsize:"4981",u
我试图通过在Ruby中进行的查询从MongoDB获取字段的子集,但它似乎不起作用。它不返回任何结果这是ruby代码:coll.find("title"=>'Halo',:fields=>["title","isrc"])#thisdoesn'twork如果我删除字段散列,它会工作,返回包含所有字段的结果coll.find("title"=>'Halo')#thisworks查看mongodb控制台,第一个查询在mongodb服务器上结束,如下所示:{title:"Halo",fields:["title","isrc"]}如果我尝试从mongo客户端控制台进行查询,它会工作,我会得到结
我有两个模型,用户和组。每个组可以有多个用户,每个用户可以在多个组中。我目前有一些简单的东西,比如:用户:has_many:groups组:has_many:users所以我有一个groups_users表,它只是用group_id和user_id创建行。我想为此添加另一列(我有),问题是如何在不使用自定义SQL调用的情况下从模型访问它?在组模型中,我可以使用self.users,在用户中,我可以使用self.groups有没有办法从用户模型更改此表中的第三列?对不起,如果这令人困惑,请就此提出建议 最佳答案 这里有一些教程应该会有
文章目录Elasticsearch和MongoDB对比关于ElasticsearchElasticsearch应用场景关于MongoDBMongoDB优点mongodb适用场景Elasticsearch和MongoDB对比Elasticsearch和MongoDB开源许可协议参考Elasticsearch和MongoDB对比关于Elasticsearch官网:https://www.elastic.co/cn/elasticsearch/Elasticistheleadingplatformforsearch-poweredsolutions.Weaccelerateresultsthatma
我有一个非常简单的程序,我尝试将商店连接到Ext.panel.Grid。我似乎无法在我的Main.js调用中获得Ext.data.StoreManager.lookup()以返回“未定义”以外的任何内容。Ext.create('LeaveRequestGrid.store.LeaveRequestStore')似乎有效(有一些警告),但我想知道正确的方法是什么。LeaveRequestStore.js:Ext.define('LeaveRequestGrid.store.LeaveRequestStore',{extend:'Ext.data.Store',storeId:'leave