duancong7573 2017-07-13 09:44
浏览 50
已采纳

如何使用Phalcon框架加入2个集合? [重复]

This question already has an answer here:

I have 2 collections which I would like to join together using the Phalcon PHP framework.

I would know how to do this in MySQL, however I am wondering if it is possible when using MongoDB, a non-relational database.

Assuming my collections are:

Robots

  • _id
  • name
  • age

Robot Parts

  • _id
  • robot_id
  • name
  • quantity
</div>
  • 写回答

1条回答 默认 最新

  • doudongdang4483 2017-07-13 09:49
    关注

    Hey Shailen & welcome to StackOverflow :)

    Even though MongoDB is not a relational database, it does allow joining of collections by using the aggregation framework which comes as part of MongoDB since version 3.2.

    You should be able to achieve this with something like:

    $results = RobotCollection::aggregate([
        [
            '$lookup' => [
                'from' => 'robot_parts',
                'localField' => '_id',
                'foreignField' => 'robot_id',
                'as' => 'parts'
            ]
        ]
    ]);
    

    In this example, the robot document will have a new field added to it 'parts' (or whatever you name it in the 'as' field of the $lookup). The parts will be matched where robot_parts.robot_id = robots._id

    You can learn more about the $lookup pipeline step here: https://docs.mongodb.com/manual/reference/operator/aggregation/lookup/#pipe._S_lookup

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效