草庐IT

arg_scope

全部标签

ruby-on-rails - rails 2.3 : How to turn this SQL statement into a named_scope

弄清楚如何从这个SQL查询创建一个named_scope有点困难:select*fromfoowhereidNOTIN(selectfoo_idfrombar)ANDfoo.category=?按RAND()限制1排序;类别应该是可变的。针对上述问题编写命名范围的最有效方式是什么? 最佳答案 named_scope:scope_name,lambda{|category|{:conditions=>["idNOTIN(selectfoo_idfrombar)ANDfoo.category=?",category],:order=>'

ruby-on-rails - 如何使 named_scope 与连接表一起正常工作?

这是我的情况。我有两个表:质押和质押交易。当用户做出promise时,他在promise表中只有一行。稍后当需要履行promise时,每笔付款都会记录在我的pledge_transactions表中。我需要能够查询到所有未结质押,即交易表中的金额之和小于质押金额。这是我目前所拥有的:named_scope:open,:group=>'pledges.id',:include=>:transactions,:select=>'pledge_transactions.*',:conditions=>'pledge_transactions.idisnotnullorpledge_trans

Ruby 闭包 : How to return args and block as a single argument to pass to a method

假设我有一个接受参数和block的方法:defyield_if_widget(*args,&block)ifargs[0].is_a?(Widget)block.callendend我可以用参数和block调用这个方法:yield_if_widget(Widget.new)doputs"Ilikewidgets"end但是如果我有另一种方法来准备参数和block呢:defwidget_and_blockargs=[Widget.new]block=proc{puts"Ilikewidgets"}[args,block]end而且我希望能够将它直接传递给第一个方法:yield_if_wi

ruby - 具有可选的第一个哈希参数和 keyword_args 的奇怪方法行为

我有以下方法:deftest(first_param=nil,keyword_arg:nil)puts"first_param:#{first_param}"puts"keyword_arg:#{keyword_arg}"end以下所有调用都按照我的预期进行:test(:something)#=>first_param:something#keyword_arg:test(nil,keyword_arg::keyword_arg)#=>first_param:#keyword_arg:keyword_argtest({first_param::is_a_hash},keyword_ar

ruby-on-rails - Rspec:使用 super(args) 初始化 Controller 类时,rspec-rails 是否存在问题?

我已经使用Rspec一段时间了,出于某种原因,我在一个名为ReferencesController的Controller上收到错误。错误表明我必须通过以下任一方式指定Controller名称:describeMyControllerdo或describe'aoeuaoeu'docontroller_name:my两种变体我都试过了:describeReferencesControllerdo和describe'refscontroller'docontroller_name:references但是我得到了两个错误!知道可能出了什么问题吗?伯恩斯编辑:由于解决方案的性质,我改写了标题并

ruby - Rails,防止 Model.scoped 的弃用警告,找到(:all) and relation #all?

我有通过但显示的测试$rspecspec/event_calendar_spec.rb......DEPRECATIONWARNING:Model.scopedisdeprecated.PleaseuseModel.allinstead.(calledfromevents_for_date_rangeat/home/durrantm/Dropbox/96_2013/work/code/ruby/event_calendar/lib/event_calendar.rb:52)DEPRECATIONWARNING:Calling#find(:all)isdeprecated.Pleasec

ruby - :replace,如何用:invalid and :undef args for encoding using CSV.读取?

自ruby​​1.9起,CSV使用可以执行编码的解析器,如果您使用如下方法:::foreach、::open、::read和::readlines。例如:CSV.read('path/to/file',encoding:"windows-1252:UTF-8")尝试读取windows-1252中的文件并返回一个数组使用utf-8编码的字符串。如果字符集之间的编码转换有未定义的字符,它会给出一个Encoding::UndefinedConversionError。String.encode方法有一些很好的参数来处理这个未定义的字符:str=str.encode('UTF-8',无效::r

ruby-on-rails - 如何对所有 ActiveRecord 模型使用通用的 named_scope

你好,如何构建对所有模型通用的命名范围。 最佳答案 我通过将这段代码放在lib/has_common_named_scopes.rb中来做到这一点:moduleHasCommonNamedScopesdefself.included(base)base.class_eval{#Namedscopesnamed_scope:newest,:order=>"#{base.table_name}.created_atDESC"named_scope:freshest,:order=>"#{base.table_name}.updated_

ruby-on-rails - rails : How to add scope to pg_search with location search?

我有两个型号,Location和Basic,我使用的是pg_search和geocodergem,如何使用geocodernear方法将范围添加到我的pg_search_scope或者是否有其他方法可以这样做?Location模型有纬度和经度列。在我的Controller中我可以这样做:#thisallowsmetosearchneartheLocationmodel@business=Location.near(params[:loc],15)#thissearchesthroughthepg_search_scope@term=Basic.search(params[:q])#I'

ruby-on-rails - ActiveRecord has_many 通过与 arg 的作用域关联

我已经看到许多问题的答案,这些问题解决了如何在ActiveRecord关联中使用范围block,包括将对象本身传递到block中,例如...classPatron(patron){baz:patron.blah},foreign_key::somekey,primary_key::somekeyendclassBar(bar){blah:bar.baz},foreign_key::somekey,primary_key::somekeyend这里使用显式主键和外键是由于底层表之间的遗留关系。生产系统中有数以亿计的“赞助人”。作为对@TJR的澄清-Patron和Bar之间的关系实际上是字