草庐IT

自定义sql

全部标签

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-on-rails - 设计的自定义身份验证策略

我需要为https://github.com/plataformatec/devise编写自定义身份验证策略但似乎没有任何文档。怎么做到的? 最佳答案 我在thisthread中找到了这个非常有用的片段在设计谷歌组初始化器/some_initializer.rb:Warden::Strategies.add(:custom_strategy_name)dodefvalid?#codeheretocheckwhethertotryandauthenticateusingthisstrategy;returntrue/falseendd

ruby - 如何将 `should validate_presence_of` 与自定义错误消息一起使用?

我正在使用Rspec测试我的ActiveRecord模型。我刚刚向我的验证之一添加了自定义错误消息,如下所示:validates:accepted_terms_at,:presence=>{:message=>'YoumustaccepttheTermsandConditionstousethissite.'}现在下面的测试失败了:it{shouldvalidate_presence_of(:accepted_terms_at)}...错误Expectederrorstoinclude"can'tbeblank"whenaccepted_terms_atissettonil。所以测试失

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、数组等的函数——我希望返回的值具有正确的类型)我的用例:我正在调用一个数据库函数,想要返回一个键

sql - GROUP BY 和 COUNT 使用 ActiveRecord

引用这个:IsthereanydifferencebetweenGROUPBYandDISTINCTGivenatablethatlookslikethis:name------barrydavebilldavedavebarryjohnThisquery:SELECTname,count(*)AScountFROMtableGROUPBYname;Willproduceoutputlikethis:namecount-------------barry2dave3bill1john1对于ActiveModel使用COUNT执行GROUPBY的正确Rails约定是什么?

ruby - 如何将自定义比较器传递给 "sort"?

A类具有以下比较器:classAattr_accessorxdefmy_comparator(a)x**2(a.x)**2endend我想使用这个比较器对每个项目都属于A类的数组进行排序:classBdefmy_methoditems.sort!()endend我应该如何将my_comparator传递给sort!? 最佳答案 定义你自己的,并包括Comparable。这是来自Comparabledoc:classSizeMattersincludeComparableattr:strdef(an_other)str.sizean_

ruby - 检查类上是否定义了方法

如何检查某个方法是否直接在某个类上定义,而不是通过继承或包含/扩展?我想要类似“foo?”的东西在以下内容中:classAdefa;endendmoduleBdefb;endendclassCfalseC.foo?(:b)#=>falseC.foo?(:c)#=>true 最佳答案 使用这个:C.instance_methods(false).include?(:a)C.instance_methods(false).include?(:b)C.instance_methods(false).include?(:c)instance

ruby - 如何在 sinatra 中引发自定义错误代码?

我在我的sinatra应用程序中执行了以下操作:disable:show_exceptionsdisable:raise_errorserrordohaml:error,:locals=>{:error_message=>request.env['sinatra.error'].to_s}endget'/error'doraise"ERROR!!"end如果我访问/error,我会得到一个500-InternalServerError响应代码,这是上帝想要的。但是如何将代码更改为404或501等?答案:disable:show_exceptionsdisable:raise_error

ruby-on-rails - 如何在 Rails 中为 Mechanize 设置自定义用户代理

我知道你有一组预定义的别名,你可以通过设置agent.user_agent_alias='LinuxMozilla'来使用,但是如果我想设置我自己的用户代理,因为我正在写一个网络爬虫并想要识别它,为了我索引的网站。就像Googlebot。似乎有一个user_agent方法,但我似乎找不到任何关于它的功能的文档。 最佳答案 您可以从别名设置用户代理a=Mechanize.newa.user_agent_alias='MacSafari'可用别名存储在AGENT_ALIASES常量中。pMechanize::AGENT_ALIASES否

ruby-on-rails - 如何自定义 rails activerecord 验证错误消息以显示属性值

当用户尝试使用已存在的名称创建记录时,我想显示如下错误消息:name"somename"已被占用我一直在努力做:validates_uniqueness_of:name,:message=>"#{name}hasalreadybeentaken"但这会输出表名而不是name属性的值 最佳答案 2件事:验证消息使用RailsI18nstyleinterpolation,即%{value}关键是value而不是name,因为在国际化的背景下,您并不真正关心模型的其余部分。所以你的代码应该是:validates_uniqueness_of