草庐IT

get_where

全部标签

ruby - Ruby 的 Object#const_get 是如何工作的?

我最近发现Ruby(2.2.1)有一些“有趣”的行为。moduleFooclassFooendclassBarendendFoo.const_get('Foo')#=>Foo::FooFoo.const_get('Bar')#=>Foo::BarFoo.const_get('Foo::Foo')#=>FooFoo.const_get('Foo::Bar')#=>NameError:uninitializedconstantFoo::Foo::BarFoo.const_get('Foo::Foo::Bar')#=>Foo::BarFoo.const_get('Foo::Foo::Foo:

ruby-on-rails - 关系 belongs_to 上的 activerecord where 子句

我不太擅长sql,对Rails也比较陌生。Caseattr_accessibleclient_idbelongs_toClientClientattr_accessibenamehas_manyCases我可以直接通过client_id查询,并按预期取回一条记录Case.where(client_id:1)但是我想通过client.name查询Case.where(client.name=>"Foo")这给我一个错误,告诉我client不是case的方法。Undefinedmethodorlocalvariable最终,我要做的非常简单:获取属于客户“Foo”的第一个案例。我希望使用的

适用于多行的 Ruby 'gets'

使用IRB,我想输入一个多行字符串,以便从中删除某些字符。“gets”只允许单行-多行是否有类似的功能。ASCII_project.rb(main):002:0*puts="What'sthetextyouwanttostrip?"=>"What'sthetextyouwanttostrip?"ASCII_project.rb(main):003:0>str=gets我现在想粘贴一段文本-因为新行它不起作用。这就是为什么我要收集多行这是代码#encoding:CP850puts="What'sthetextyouwanttostrip?"str=getsstr.gsub!(/\P{AS

ruby-on-rails - 两个表上的 Rails where 子句

我在rails应用程序中有以下模型category=>company=>storeStore有一个belongs_to公司,company有一个belongs_to类别关系。现在我想在商店对象上使用where方法来检索同一类别中的所有商店。我想要这样的东西@stores.nearbys(5).where("stores.company.category_id=xxx")谁能给我一些建议 最佳答案 尝试用连接表上的where连接:@stores.nearbys(5).joins(:company).where("companies.c

ruby-on-rails - rails : Return only objects where all associations meet a condition

设置:Rails3.2.18、Postgres我有两个对象,例如,将它们称为Author和Article,具有以下设置:classAuthorhas_many:articles...endclassArticlebelongs_to:authorclass我正在尝试查找所有Author记录,其中所有相关的Article记录都是在一年前发布的。这段代码:Author.joins(:article).merge(Article.published_over_one_year_ago)...返回Author对象,其中至少一个关联的Article是在一年多以前发表的,但我只需要作者记录,其中所

ruby - Rails 3 - 测试 Controller 的 GET 方法 - 尝试使用 JSON 并出现 406 错误

我有一个简单的Controller,它指定:respond_to:json当我尝试构建这样调用它的功能测试时:test"GET"doget'index',:format=>:jsonend一切正常。但是,如果我尝试像这样传递查询参数:test"GET"doget'index',{:my_param='1234'},:format=>:jsonend我收到Controller返回的406错误。如果我通过response.inspect转储响应,我可以看到@status=406和@header的内容类型为文本/html。如果我通过response.inspect为不传递查询参数的简单情况转

ruby-on-rails - 将 form_for 标签与 get 方法一起使用

我正在尝试使用get方法提交表单。早些时候我尝试用form_tag做类似的事情并且它工作正常但现在当我更改为form_for标签时,这似乎不起作用。filter_path,:method=>:get)do|f|%>我收到一个无路由错误。 最佳答案 如果需要,您可以使用:html传递原始HTML属性。对于Rails3:filter_path,:html=>{:method=>'GET'})do|f|%>更新并且在Rails4中,根据下面@andre.orvalho的建议,可以直接提供method参数:

ruby-on-rails - 在 Rails3 中使用 .where 方法

我刚刚开始使用.where方法,我对如何充分利用它有点困惑。我想做这样的事情:@books=Book.where(:author_id=>1||2)显然我知道这行不通,但我试图证明我需要一些额外的逻辑。一些“或”“和”“不等于”等。关于我可以在哪里研究这个的任何想法?我正在查看RailsAPI,但没有看到任何有用的信息。谢谢! 最佳答案 1||2将不起作用,因为该表达式在函数调用之前被评估(它评估为1,因此它应该等效于Book.where(:author_id=>1)。我会做:@books=Book.where(:author_id

ruby - 导轨 : how to get a file extension/postfix based on the mime type

我的问题是,RubyonRails是否具有类似于以下的功能:file_content_type=MIME::Types.type_for(file).first.content_type这将返回特定mime类型的文件扩展名或后缀?所以如果我传入'image/jpeg'函数将返回'jpg'寻找一种比编写完成相同工作的case语句更简洁的编码方式。 最佳答案 Rack::Mime具有这种能力(Rack是Rails的依赖):require'rack/mime'Rack::Mime::MIME_TYPES.invert['image/jpe

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl