草庐IT

sql - MySql:计算价格范围内的行数?

全部标签

ruby-on-rails - 有没有办法在 Rails 控制台内的输出上实现类似 grep 的功能

在shell中,我可以做到$catname_of_file_with_a_lot_of_text|grep"WhatIamlookingfor"在Rails控制台中,我能否实现类似的功能,比如当我运行一个命令并且输出很大时,尤其是数据库查询。我知道将其输出为YAML,但这不是我要找的。谢谢。 最佳答案 是的,你可以。该方法称为gr...等待它...ep。Ruby的grep适用于String、Array和许多其他内置对象。例如,要获取一个数字的所有to_xxx方法,只需执行以下操作:1.methods.grep(/to_/)

sql - 将所有 Controller 操作包装在 Rails 中的事务中

是否可以设置一个Rails应用程序,以便所有Controller操作都自动包装在一个事务中,并在出现未挽救的异常时自动回滚?我正在开发一个Rails3应用程序,目前正在执行一项相当棘手的操作,该操作会进行大量数据库更改。而且我一直弄错了很多次!一段时间后,我意识到我的代码无法正常工作,因为我最终在数据库中得到了不一致的数据。我可以很容易地用一个事务来包装它(这是一个明显需要的实例!)。然而,这让我想到,至少在开发过程中,将这个想法应用于每个Controller操作会很有用。假设这是可能的,这有什么缺点吗? 最佳答案 有关信息,我在我

ruby-on-rails - SQL 注入(inject)和 ActiveRecord

这对SQL注入(inject)安全吗:Guest.where(:event_id=>params[:id])我在发送params[:id]时没有进行任何类型的清理。一般来说,所有这些activerecord方法都安全吗?(如where、joins等。)如果不是,安全的最佳做法是什么?另外,是否有任何我应该注意的警告/边缘情况?谢谢 最佳答案 ActiveRecord的所有查询构建方法,如where、group、order等等,都可以安全地防止SQL注入(inject)ASLONGAS您不向它们传递原始SQL字符串。这容易受到SQL注

ruby - 如何将整数数组总结为范围数组?

我想接受如下输入:[1,2,4,5,6,7,9,13]然后把它变成类似下面的东西:[[1,2],[4,7],[9,9],[13,13]]每个子数组代表一个整数范围。 最佳答案 使用Enumerable#chunk的函数式方法:ranges=[1,2,4,5,6,7,9,13].enum_for(:chunk)#.chunkforRuby>=2.4.with_index{|x,idx|x-idx}.map{|_diff,group|[group.first,group.last]}#=>[[1,2],[4,7],[9,9],[13,1

sql - 在 AREL 中分组 ands 和 ors

我正在尝试使用arel查询此sql片段的等效项:WHERE(("participants"."accepted"='f'AND"participants"."contact_id"=1)OR"participants"."id"ISNULL)所以我想要(accepted&&contact_id=1)ORNULL这是我在AREL中得到的participants[:accepted].eq(false).and(participants[:contact_id].eq(1).or(participants[:id].is(nil)问题是,这会产生:("participants"."acce

ruby-on-rails - Rails gem rails3-jquery-autocomplete 如何按用户范围

我正在使用Railsgemrails3-jquery-autocomplete为帖子添加类别。我想将搜索限制为在结果中仅包含属于当前用户或帖子作者的类别。文档说我可以指定范围::scopesAddedoptiontousescopes.Passscopesinanarray.e.g:scopes=>[:scope1,:scope2]但我不确定如何在此处传递用户ID?这似乎是一个常见的场景,我是否遗漏了一些明显的东西?我找到了一个建议修改get_item方法的答案,但这似乎破坏了自动完成Scopingtheresultsforrails3jqueryautocompleteplugin

ruby-on-rails - Has_Many :Through or :finder_sql

我已经确定了我想要的东西,但我似乎无法以Rails设计师正在寻找的方式获得它。基本上,我有(请搁置多元化/等问题):人类关系(parent、后代)我正在尝试获取单亲的所有后代,以及许多后代的单亲(假设每个后代只有一个parent)。我可以在模型中通过以下方式做到这一点:has_one:parent,:through=>:relationships,:foreign_key=>:human_id,:source=>:source_humanhas_many:offsprings,:finder_sql=>'SELECTDISTINCToffsprings.*'+'FROMhumansof

ruby-on-rails - 如何计算Float中的小数位数?

我正在使用Ruby1.8.7和Rails2.3.5。如果我有一个像12.525这样的float,如何获取小数点后的位数?在这种情况下,我希望得到“3”。 最佳答案 我猜是这样的:n=12.525n.to_s.split('.').last.size 关于ruby-on-rails-如何计算Float中的小数位数?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8597766/

ruby - 我可以在 Ruby 中获取 'ensure' 内的返回值吗?

defsome_methodputs'inmethod'return'Iamareturnvalue'ensureputs'willprintattheend'#CanIsomehowgetthereturnvalueofsome_methodhere?end是否有一些(可能是元编程)原则/方法来获取“确保”子句内方法的返回值,该子句是方法定义的一部分(我们都知道无论如何都会执行)? 最佳答案 分配一个变量只是让你的返回值成为一个变量。您可以在ensure语句中使用该变量,但该方法的返回值将是该方法的非异常部分中评估的最后一条语句。

ruby - 了解范围和数组中的 ruby​​ splat

我试图理解*(1..9)和[*1..9]之间的区别如果我将它们分配给变量,它们的工作方式相同splat1=*(1..9)#splat1=[1,2,3,4,5,6,7,8,9]splat2=[*1..9]#splat2=[1,2,3,4,5,6,7,8,9]但是当我尝试直接使用*(1..9)和[*1..9]时,事情变得很奇怪。*(1..9).map{|a|a.to_s}#syntaxerror,unexpected'\n',expectingtCOLON2or'['or'.'[*1..9].map{|a|a.to_s}#["1","2","3"...]我猜部分问题出在运算符的优先级上?但