在我发现的许多在上限集合上使用可尾游标的示例中,代码包括:
hint( { $natural: 1 } )
(例如 here ),包括官方文档 ( here ),以“确保我们不使用任何索引”,并且结果以自然(即磁盘)顺序返回。
但是,文档还表明这是可尾游标的默认行为:
Tailable cursors do not use indexes and return documents in natural order.
那么提示的使用是多余的吗?
我试着查看 explain() 的输出,有和没有 hint,据我所知,没有区别。
最佳答案
是的,是的。
有时你可能想做的是以相反的自然顺序返回结果(最后插入的文档最先返回。你可以通过以下方式实现:
db.cappedCollection.find().sort({$natural:-1})
有效地将上限集合的 FIFO 性质更改为 LIFO 性质。
关于mongodb - 是提示({$自然: 1}) redundant when using a tailable cursor?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26573454/
我想在IRB中浏览文件系统并让提示更改以反射(reflect)当前工作目录,但我不知道如何在每个命令后进行提示更新。最终,我想在日常工作中更多地使用IRB,让bash溜走。我在我的.irbrc中试过这个:require'fileutils'includeFileUtilsIRB.conf[:PROMPT][:CUSTOM]={:PROMPT_N=>"\e[1m:\e[m",:PROMPT_I=>"\e[1m#{pwd}>\e[m",:PROMPT_S=>"FOO",:PROMPT_C=>"\e[1m#{pwd}>\e[m",:RETURN=>""}IRB.conf[:PROMPT_MO
我有一个Highstock图表(带有标记和阴影的线条),并且想以编程方式显示一个highstock工具提示,例如,当我选择某个表上的一行(包含图表数据)我想显示相应的highstock工具提示。这可能吗? 最佳答案 股票图表thissolution不起作用:在thisexample你必须更换这个:chart.tooltip.refresh(chart.series[0].data[i]);为此:chart.tooltip.refresh([chart.series[0].points[i]]);解决方案可用here.
有人知道类似于Date.js的东西吗?在ruby?能够从诸如“从今天起两周”之类的东西返回日期对象的东西。RemembertheMilk网络应用程序将此功能整合到他们的系统中,而且非常易于使用。我会使用Date.js库本身,但因为它在客户端,所以有其局限性。如果用户没有启用javascript,则该功能将丢失。这会影响手机用户,理想情况下,他们会通过短信(sms)使用我们的系统。我很想使用已经存在的解决方案,但如果不是,将此代码移植到Ruby中会有多难?我真的不太了解自然语言解释,但似乎需要一些时间。谢谢。 最佳答案 不要忘记在Ru
我正在使用事件资源从api获取数据并显示它,我的Controllermodel.rb有classThr::Vol::Dom'/vv/test/domains/2013-06-25T05:03Z')xendend当我调用Thr::Vol::Dom.find方法时,它返回以下错误:ArgumentError:expectedanattributesHash,got["0.0.0.0","1.1.1.1","2.2.2.2","3.3.3.3","4.4.4.4"]该api应该提供这样的内容{"abs.com":["0.0.0.0","1.1.1.1","2.2.2.2","3.3.3.3"
我添加到我的.irbrc:IRB.conf[:PROMPT].reverse_merge!(:RAILS_ENV=>{:PROMPT_I=>"#{current_app}#{rails_env}#{prompt}",:PROMPT_N=>"#{current_app}#{rails_env}#{prompt}",:PROMPT_S=>nil,:PROMPT_C=>"?>",:RETURN=>"=>%s\n"})IRB.conf[:PROMPT_MODE]=:RAILS_ENV如果我这样做:current_app="\e[31mfoo_bar_app\e[0m"rails_env="\e
在3.0之前有一种方法可以做到这一点:#...set:mysql_password,proc{Capistrano::CLI.password_prompt"Gimmeremotedatabaseserverpassword.Don'tworry,Iwon'ttellanyone:"}#...namespace:dbdodesc'Dumpremotedatabase'task:dumpdorun"mysqldump-u#{mysql_user}-p#{mysql_database}>~/#{mysql_database}.sql"do|channel,stream,data|ifdat
我是那些没有在他的任何Ruby/RubyonRails工作中使用TextMate的开发人员之一。我在这个领域的特别忠诚在于vim。您最喜欢将vim与Ruby和/或RubyonRails结合使用以尽可能提高工作效率的提示/技巧是什么? 最佳答案 最重要获取rails.vim的副本它在数百万级别上很棒。Readthedoc.提示太多了,:Rviewcustomer,:RSmodelfoo,:Rinvert,gf,:Rextract,:Rake等等。您可能需要NERDTree以及轻松导航(您可以使用:Rtree访问)第二重要在推特上关注t
我正在使用rvm-prompt.似乎解释器、版本、补丁级别和gemset都应该默认显示。如果我调用提示,它会准确地返回当前的ruby和gemset:$rvm-promptruby-1.8.7-p302@rails125但是我的gemset没有反射(reflect)在我的提示中:ruby-1.8.7-p302MacBook:~subpixel$我尝试在.bash_profile中显式调用gemset:PS1="\$(~/.rvm/bin/rvm-promptivpg)$PS1"但它不会更改提示。 最佳答案 如果您查看rvm-pro
我可以在一个Rails应用程序中同时使用MongoDB和PostgreSQL吗?具体来说,我最终会想要使用像MongoHQ这样的东西。到目前为止,我未能在实验中进行这项工作。令我担心的是,MongoDB文档特别指出我必须禁用ActiveRecord。任何建议将不胜感激。 最佳答案 您无需禁用ActiveRecord即可使用MongoDB。查看Mongoid只需将gem加上任何模型与您现有的任何ActiveRecord模型一起添加。您应该注意到MongoHQ只是MongoDB的托管服务,可以与任何对象文档映射器(ODM)一起使用。更多
我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序