jjzjj

mongodb - NoSql self 加入喜欢

coder 2023-11-04 原文

我想了解我是否可以以任何方式使用 NoSql 执行以下操作。我将以航类为例。

假设我有包含以下信息的航类表或集合:

...
{ from:XXX, to:YYY, date:01-01-2016 } 
{ from:YYY, to:XXX, date:02-02-2016 }
...

我需要能够执行诸如自连接之类的操作来找到完整的路线:
{from:XXX, to:YYY, outbound:01-01-2016, inbound:02-02-2016}

表格应该有很多 fromto 位置。

是否可以在没有关系数据库的情况下做到这一点?

最佳答案

Is it possible to do it with no relational DB?

这个问题问错了。 NoSQL 的理念是针对特定问题使用专门数据存储,而不是试图用同一个工具解决所有问题。

您的用例尚不清楚,但是 - 根据您用来查询的数据,您可以简单地执行两个查询并合并结果,或者使用简单的 $or 查询(在mongodb) 来回查询路径。有多种方法可以使用各种工具解决此问题,但这取决于您要解决的确切问题。

航类示例甚至不适合 RDBMS,因为这通常是 routing problem在可能允许(或必要)为每个方向组合两个或多个航类的地方 - neo4j 可能是解决图形问题的更简单工具(请注意,我不是说“更好”,因为那可以意味着很多事情......)

关于mongodb - NoSql self 加入喜欢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28884890/

有关mongodb - NoSql self 加入喜欢的更多相关文章

  1. ruby - 如何离开加入Arel? - 2

    Arel3.0.2提供了两个类来指定连接类型:Arel::Nodes::InnerJoin和Arel::Nodes::OuterJoin并使用InnerJoin默认。foo=Arel::Table.new('foo')bar=Arel::Table.new('bar')foo.join(bar,Arel::Nodes::InnerJoin)#innerfoo.join(bar,Arel::Nodes::OuterJoin)#outerfoo.join(bar,???)#left如果要生成左连接,如何连接两个表? 最佳答案 你可以使用

  2. sql - 不同的加入 Rails - 2

    视频有很多事件我正在尝试获取所有在未来安排了事件的视频。我已经有了这个:named_scope:scheduled_in_future,:joins=>:event,:conditions=>["event.scheduled_start>?ANDevent.status=?",Time.now.to_i,'PENDING']这行得通,但如果同一个视频在未来有多个事件,它会给我重复的视频记录。当然,我可以遍历数组并清除重复项,但必须有一种SQL方法才能做到这一点。我尝试添加一个:select=>"DISTINCT(video.id)"但它只返回ID字段而不是整个记录。

  3. ruby - 你最喜欢 Ruby 的什么特性? - 2

    就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter为指导。9年前关闭。已向.NET提出类似问题和Java,但不适用于Ruby。所以,你最喜欢Ruby的什么特性?您可能还对hiddenfeaturesofRuby感兴趣.请具体说明,并为每个答案发布一项功能。解释或代码示例会很好。 最佳答案 块非常好:my_array.each{|element|printelement}#.

  4. ruby-on-rails - 仅当该表尚未加入时才可以加入 "dynamically"表吗? - 2

    我正在使用RubyonRails3.2.2,我想知道在范围方法中是否可以“动态”连接一个表,前提是该表尚未连接。那它,我有:defself.scope_method_name(user)joins(:joining_association_name).where("joining_table_name.user_id=?",user.id)end我想做如下的东西:#Note:thefollowingcodeisjustasampleinordertounderstandwhatImean.defself.scope_method_name(user)iftable_is_joined?

  5. ruby-on-rails - 如何获取具有 min has_many 记录的记录(加入数据) - 2

    用户.rbhas_many:properties属性.rbbelongs_to:user我想获得一个具有最小属性的用户,例如wiseformax。我找不到任何相关的查询 最佳答案 要找到具有min属性的用户,您可以简单地做,User.joins(:properties).group("properties.user_id").order("count(properties.user_id)desc").last并找到具有max属性的用户,User.joins(:properties).group("properties.user_i

  6. ruby-on-rails - 在一个 Rails 应用程序中使用 PostgreSQL 的 MongoDB - 2

    我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多

  7. ruby - 使用 mongodb/mongoid 运行时更改模型 - 2

    我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序

  8. ruby - 您更喜欢在 Ruby 中如何定义类方法? - 2

    JohnNunemaker最近写了关于variouswaystodefineclassmethods的博客在Ruby中,给出这三种选择:#Way1classFoodefself.barputs'classmethod'endend#Way2classFooclass您首选的方法是什么?您还喜欢上述以外的东西吗?如果您使用不止一种方式,您在什么情况下使用它们? 最佳答案 我一直使用方法1:classFoodefself.barputs'classmethod'endend它并不冗长,而且它使方法保持在类的相同上下文中。

  9. ruby-on-rails - 我如何从 Ruby 代码连接到 mongodb? - 2

    我如何从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")

  10. ruby - MongoDB:无法从 BSON 类型 EOO 转换为 Date - 2

    我正在尝试使用聚合框架(使用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

随机推荐