草庐IT

mongodb - Mongodb 空间查询 $geoNear 与 $near

全部标签

ruby-on-rails - 如何获取触发查询的代码行?

在rails3.2中是否有一种方法(一个gem、一个插件或其他东西)来知道哪一行代码触发了一个数据库查询?例如在我的日志中我有:UserLoad(0.4ms)SELECT`users`.*FROM`users`WHERE`users`.`id`=5LIMIT1如何知道触发查询的代码行?谢谢... 最佳答案 我找到了这个解决方案:moduleQueryTracedefself.enable!::ActiveRecord::LogSubscriber.send(:include,self)enddefself.append_featur

ruby - 是否有可能获得命名空间中所有可用 rake 任务的列表?

是否有可能从rake任务中获取命名空间中的任务列表?一种程序化的“rake-Tdb”? 最佳答案 我找到了答案:tasks=Rake.application.tasks这将返回一个可以检查的Rake::Task对象数组。更多详细信息,请访问http://rake.rubyforge.org/ 关于ruby-是否有可能获得命名空间中所有可用rake任务的列表?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c

ruby-on-rails - 在 Rails 中通过 belongs_to 关系查询记录

我有一个事件模型,它们属于一个位置如何选择location.country=Australia的所有事件?(例如)我可以在一个范围内这样做吗? 最佳答案 使用最新的rails版本,您可以:Activity.joins(:location).where(locations:{country:"Australia"})注意:它是joins(:location)中的位置(单数),因为它引用了belongs_to关系名称它是where(…)中的位置(复数),因为它引用了表名后者意味着如果您有以下情况:belongs_to:location,

ruby - 使用 ActiveRecord 在查询对象中转义参数?

给定一个查询对象(不是AR模型)classComplexQueryQUERY=如何方便地转义所有参数?我成功地使用了三种技术,但没有一种是方便的。使用raw_connection(对我而言)返回PG::Conn的实例并调用exec_params。我对此并不满意,因为exec_params需要一组详细的参数来指定数据类型。在我的查询对象中包含ActiveRecord::Sanitization并使用其中一种方便的方法,例如replace_named_bind_variables。我对此不满意,因为replace_named_bind_variables是protected并且我必须使用s

ruby - 如何抢救某个命名空间下的所有异常?

有没有办法拯救某个命名空间下的所有异常?例如,我想挽救所有Errno::*异常(Errno::ECONNRESET、Errno::ETIMEDOUT)。我可以继续将它们全部列在我的异常行中,但我想知道我是否可以做类似的事情。begin#mycoderescueErrno#handleexceptionend上面的思路好像不行,有没有类似的可以实现? 最佳答案 所有ErrnoexceptionssubclassSystemCallError:ModuleErrnoiscreateddynamicallytomaptheseoperat

sql - 何时使用 ORM(Sequel、Datamapper、AR 等)与纯 SQL 进行查询

我的一位同事目前正在设计如下所示的SQL查询以生成报告,这些报告通过外部数据查询显示在excel文件中。目前只需要DB上的上报流程(无CRUD操作)。我试图说服他最好使用ruby​​ORM以便能够在rails/sinatra应用程序中显示数据。尽管在显示数据方面有明显的优势,但学习使用像Sequel或Datamapper这样的ORM对他有什么优势?他正在编写的SQL查询显然相当复杂,并且对SQL比较陌生,他经常提示它非常耗时且令人困惑。是否可以使用ORM编写极其复​​杂的查询?如果是这样,哪个最合适(我听说Sequel对遗留数据库有好处)?在进行复杂的数据库查询时,学习Ruby和使用O

ruby - 在 ruby​​ 中获取可用磁盘空间

使用ruby​​获取磁盘空间信息的最佳方法是什么。我更喜欢纯ruby解决方案。如果不可能(即使有额外的gem),它也可以使用标准ubuntu桌面安装中可用的任何命令将信息解析为ruby​​。 最佳答案 您可以使用sys-filesystemgem(跨平台友好)require'sys/filesystem'stat=Sys::Filesystem.stat("/")mb_available=stat.block_size*stat.blocks_available/1024/1024 关于

ruby-on-rails - 在 rails 中过滤 ActiveRecord 查询

我习惯了Django,在那里你可以在查询集上运行多个过滤方法,即Item.all.filter(foo="bar").filter(something="else")。然而,这在Rails中并不容易。Item.find(:all,:conditions=>["foo=:foo",{:foo=bar}])返回一个数组,这意味着这将不起作用:Item.find(:all,:conditions=>["foo=:foo",{:foo='bar'}]).find(:all,:conditions=>["something=:something",{:something='else'}])所以我

ruby-on-rails - 如何在 Rails 控制台中查看 MySQL 查询

这个问题在这里已经有了答案:HowtoshowSQLqueriesrunintheRailsconsole?(8个答案)关闭8年前。有没有办法在Rails控制台中查看从ActiveRecord触发了哪些MySQL查询?

ruby-on-rails - 在没有额外的 sql 查询的情况下过滤 activerecord 关系?

如何在不执行额外查询的情况下过滤AR查询的结果?例如u=User.where(name:"bob",age:[10,20])#1stselectquerytodbu.class#ActiveRecord::Relationtens=u.where(age:10)#2ndselectquerytodb我不希望第二个查询调用数据库,而是过滤在u(第一个查询)中检索到的结果。 最佳答案 ActiveRecord:Relation仅在访问其元素时查询数据库。因此,您拥有的序列根本不会调用数据库,除非您编写类似u.first或tens.fir