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如果要生成左连接,如何连接两个表? 最佳答案 你可以使用
视频有很多事件我正在尝试获取所有在未来安排了事件的视频。我已经有了这个:named_scope:scheduled_in_future,:joins=>:event,:conditions=>["event.scheduled_start>?ANDevent.status=?",Time.now.to_i,'PENDING']这行得通,但如果同一个视频在未来有多个事件,它会给我重复的视频记录。当然,我可以遍历数组并清除重复项,但必须有一种SQL方法才能做到这一点。我尝试添加一个:select=>"DISTINCT(video.id)"但它只返回ID字段而不是整个记录。
我正在使用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?
用户.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
给定classCategory'nameASC'end使用Rails3堆栈,我如何查询“有”产品的所有类别? 最佳答案 在ARel(不是ActiveRecord)中,我们将执行以下操作:p=Arel::Table.new:products#BaseRel-varc=Arel::Table.new:categories#BaseRel-varpredicate=p[:category_id].eq(c[:id])#forequalitypredicatep.join(c)#Naturaljoin.on(predicate)#Equi-
在下面的代码中,我们必须使用?字符加入url.path和url.query吗?有更优雅的方法吗?我必须使用net/http,因为在某些情况下我也想在用户代理的header中放置一个字符串。require'net/http'url_string='http://www.time.gov/timezone.cgi?Pacific/d/-8'url=URI.parse(url_string)response=Net::HTTP.start(url.host,url.port)do|http|http.get(url.path+'?'+url.query)endputsresponse.bod
我有一个包含很多硬币的Collection类。我正在尝试选择包含两个以上硬币的收藏品。目前,我可以直接通过Ruby来实现这一点,但效率极低。我当前的代码:collections=Collection.all.select{|c|c.coins.count>2}如何通过与Arel的joins调用来实现这一点?谢谢! 最佳答案 回答我自己的问题:Collection.joins(:coins).group("coins.collection_id").having("count(coins.id)>2")向KJF致敬谁问thissimi
我喜欢加入一个数组,生成一个“英文列表”。例如['one','two','three']的结果应该是'one,2andthree'。我写了这段代码来实现的(假设数组不为空,我的情况不是这样)ifarray.length==1result=array[0]elseresult="#{array[0,array.length].join(',')}and#{array.last}"end但我想知道是否存在一些“高级”连接方法来实现这种行为?或者至少是一些更短/更好的代码? 最佳答案 这样的方法在核心Ruby中不存在。已经implemen
我正在阅读一个包含源代码的文件。我需要在每行前附加2个空格。这就是我正在做的。data=read_filedata.split(/\n/).collect{|l|''+l}.join('\n')但是,当我加入后,它会按字面打印\n而不是换行符。我该如何解决? 最佳答案 您需要使用双引号(")而不是单引号。因此请替换为:'\n'用这个:"\n"阅读更多相关信息here.如果您希望行尾是CRLF而不是LF,则可能需要使用\r\n(某些Windows记事本等编辑器不会看到LF换行符)。 关于r
我正在尝试找到一种将部分url路径段连接在一起的可靠方法。有没有快速的方法来做到这一点?我尝试了以下方法:putsURI::join('resource/','/edit','12?option=test')我希望:resource/edit/12?option=test但是我得到了错误:`merge':bothURIarerelative(URI::BadURIError)我过去曾为此使用过File.join(),但将文件库用于url似乎有些不对。 最佳答案 URI的api不一定很好。URI::join仅当第一个作为带有协议(pr