草庐IT

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

ruby - 从 ActiveRecord 原始 SQL 获取类型化结果

在Sequel中,我可以做到:irb(main):003:0>DB["selectfalse"].get=>false返回一个错误的bool值。我希望能够在ActiveRecord中做类似的事情:irb(main):007:0>ActiveRecord::Base.connection.select_value"selectfalse"=>"f"如您所见,它返回字符串"f"。有没有办法用ActiveRecord得到一个错误的bool值?(类似地,我可能正在调用一个返回timestamptz、数组等的函数——我希望返回的值具有正确的类型)我的用例:我正在调用一个数据库函数,想要返回一个键

Ruby:如果更改了文件,则再次需要一个文件

我写了一个在config/中查找配置文件的gem。这工作正常,但如果用户更改任何配置,他们必须停止程序并在我的gem加载新配置之前重新启动它。这将要求他们在每次更改时重新启动整个Rails应用程序,这并不理想。有没有办法“重新要求”一个文件,以便它重新加载它而不是使用缓存的版本。 最佳答案 您可以使用load代替require。这将加载文件,而不管它之前是否已经加载过。请注意,对于load,您需要指定.rb扩展名,它对于require是可选的。所以require"path/to/myconfig"变成了load"path/to/my

ruby - 在 Sinatra 中,你如何制作一个 "before"过滤器来匹配除某些路由之外的所有路由

我有一个RubySinatra应用程序,我有一些代码需要在除少数异常(exception)情况外的所有路由上执行。我该怎么做?如果我想在选定的路由(白名单样式)上执行代码,我会这样做:['/join',"/join/*","/payment/*"].eachdo|path|beforepathdo#somecodeendend我该如何反其道而行之(黑名单样式)?我想匹配除'/join'、'/join/*'和'/payment/*'之外的所有路由 最佳答案 负面前瞻:before/^(?!\/(join|payment))/do#..

ruby - 将 pp 的结果(或输出到控制台的任何内容)放入字符串中

我们知道require'pp'a=["value1","value2","value3"]ppa漂亮地将数组作为输出打印到控制台。我如何将漂亮的输出转换为字符串(一个包含使事情变得漂亮的换行符的字符串等)?...目的是从方法中返回漂亮的字符串。 最佳答案 string_value=a.pretty_inspect#pretty_inspect也会在您第一次需要“pp”时出现-请参阅:http://ruby-doc.org/stdlib-2.1.0/libdoc/pp/rdoc/Kernel.html#method-i-pretty_

ruby - 为什么我的 Ruby 'ri' 工具不在命令提示符中返回结果?

这个问题在这里已经有了答案:关闭11年前。社区在上个月审查了是否重新打开此问题并使其关闭:原始关闭原因未解决PossibleDuplicate:ruby1.9riproblem当我尝试在命令提示符窗口中使用Ruby的ri工具来获取有关类、方法等的帮助时,它似乎总是失败。例如,如果我输入:riArray我收到一条消息说:Updatingclasscachewith0classes...NothingknownaboutArray我使用的是安装了Ruby1.9.1p243(2009-07-16修订版24175)[i386-mingw32]的Vista64。我应该如何配置ri才能工作?

ruby-on-rails - 如何将自定义过滤器添加到 Active Admin?

事件管理员允许我definefilters像这样显示在索引页上:ActiveAdmin.registerPromodofilter:namefilter:addressfilter:cityfilter:statefilter:zipend我想将以上所有字段合并为一个,这样我就可以搜索在名称或完整地址中包含搜索字符串的促销。我的模型已经有一个我可以使用的命名范围:classPromo"%#{q}%")}end 最佳答案 活跃的管理员使用元搜索。例如你可以这样做:filter:"subscription_billing_plan_na

ruby - 如何过滤哈希数组以仅获取另一个数组中的键?

我正在尝试为数组中的每个散列获取键的子集。哈希实际上要大得多,但我认为这更容易理解:[{id:2,start:"3:30",break:30,num_attendees:14},{id:3,start:"3:40",break:40,num_attendees:4},{id:4,start:"4:40",break:10,num_attendees:40}]我只想获取id和start值。我试过:return_keys=['id','start']return_array=events.select{|key,val|key.to_s.in?return_keys}但这会返回一个空数组。

ruby-on-rails - 安装 mysql2 (0.3.11) 时出错

我是一个Rails初学者,我从https://github.com/rubytaiwan/jobs.ruby.tw得到了一个演示。但是当我尝试运行这个演示时,我得到了一个错误。我跟着跑bundle我得到了错误Anerroroccurredwhileinstallingmysql2(0.3.11),andBundlercannotcontinue.Makesurethat`geminstallmysql2-v'0.3.11'`succeedsbeforebundling.但我可以确定我已经安装了mysql2Gemfile是source'https://rubygems.org'ruby"

ruby-on-rails - Ruby、RVM、LLVM 和 MySQL

我在MacOSX上配置Ruby和MySQL时遇到了很大的麻烦。事实上,我是MacOSX和RubyOnRails的新手。所以,首先我在安装mysql2gem时遇到了问题,在安装gem之后,我正在尝试开发人员进行测试,当我尝试启动WEBrick时出现此错误,指出无法加载名为“libmysqlclient.xml”的MySQL库。18.dylib”。关于错误的谷歌搜索,我看到每个人都在推荐通过RVM使用Ruby。我安装了RVM并尝试安装ruby​​1.9.3并收到此错误:ERROR:TheprovidedCC(/usr/bin/gcc)isLLVMbased,itisnotyetfullys