草庐IT

activerecord-oracle_enhanced-adap

全部标签

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

ruby-on-rails - ActiveRecord::Errors 的 Rails 3 替代品是什么?

ActiveRecord::Errors的Rails3替代品是什么?在Rails2.3.8中,这是一个对象:>>ActiveRecord::Errors=>ActiveRecord::Errors在Rails3.0.0rc中,你会得到一个NameError:>>ActiveRecord::ErrorsNameError:uninitializedconstantActiveRecord::Errorsfrom(irb):2我正在尝试制作wizardly生成器与Rails3一起工作。$railsgwizardly_scaffoldhome但失败了:/Library/Ruby/Gems/1

ruby-on-rails - Rails 使用逻辑运算符搜索 ActiveRecord

我想知道在Rails中解析文本查询的最佳方法是什么,以允许用户包含逻辑运算符?我希望用户能够输入其中任何一个,或一些等效的:#searchingpartialtextinemails,justforexample#queryA"jonANDgmail"#=>["jonsmith@gmail.com"]#queryB"jonORgmail"#=>["jonsmith@gmail.com","sarahcalaway@gmail.com"]#queryC"jonANDgmailANDsmith"#=>["jonsmith@gmail.com"]理想情况下,我们可以使用括号来指示操作顺序,从

ruby-on-rails - Rails,activerecord : self[:attribute] vs self. 属性

在Rails中访问事件记录列/属性时,使用self[:attribute]与self.attribute有什么区别?这会影响getter和setter吗? 最佳答案 它们都只是获取属性的方法-它们都只是getter。self.attribtue是一个更“传统”的getter,而self[:attribute]基本上只是[]方法。在使用两者之间切换不会产生任何影响。我建议只使用self.attribute方法,因为它在语法上更好。但是,当其他内容覆盖self.attribute方法时,使用self[:attribute]会派上用场。例

ruby-on-rails - 关系 belongs_to 上的 activerecord where 子句

我不太擅长sql,对Rails也比较陌生。Caseattr_accessibleclient_idbelongs_toClientClientattr_accessibenamehas_manyCases我可以直接通过client_id查询,并按预期取回一条记录Case.where(client_id:1)但是我想通过client.name查询Case.where(client.name=>"Foo")这给我一个错误,告诉我client不是case的方法。Undefinedmethodorlocalvariable最终,我要做的非常简单:获取属于客户“Foo”的第一个案例。我希望使用的

ruby-on-rails - Ruby Gem ActiveRecord 具有多个条件的查找方法

我正在使用三个数据库表构建一个Sinatra应用程序:user、post和like。我想运行一个查询来在like表中找到一个条目,如下所示:FINDinlikeWHEREuser_id==params[:user_id]ANDpost_id==params[:post_id](对于一种情况,我将使用:Like.find_by_user_id(params[:user_id]))我的问题是:如何使用ActiveRecordGem运行具有多个条件的查找查询? 最佳答案 使用where:Like.where('user_id=?ANDpo

ruby-on-rails - ActiveRecord .... activerecord-mysql-adapter

这让我发疯。我正在尝试创建一个简单的初学者应用程序,利用ActiveRecord来执行简单的数据库任务。我没有使用Rails。我不断收到错误:RuntimeError:Pleaseinstallthemysqladapter:`geminstallactiverecord-mysql-adapter`(Couldnotfindmysql(~>2.8.1)amongst[actionmailer-3.1.3,actionpack-3.1.3,activemodel-3.1.3,activerecord-3.1.3,activerecord-sqlserver-adapter-3.1.4,

ruby-on-rails - rails ActiveRecord : Multiple conditions in find

这可能更像是一种Ruby语法。我很难在SomeObject.find上获得两个限制条件。分离,条件似乎可行:ifsearch!=''find(:all,:conditions=>['nameLIKE?',"%#{search}%"])elsefind(:all,:conditions=>['active',1]).shuffleend第一个案例我要的是:find(:all,:conditions=>['nameLIKE?',"%#{search}%"],['active',1])但是该行抛出语法错误,意外的')',期待tASSOC。 最佳答案

ruby-on-rails - 如何随机化 `ActiveRecord::Relation` 的数组元素位置?

我正在运行RubyonRails3.2.2,我想随机化ActiveRecord::Relation的数组元素位置。我该怎么做? 最佳答案 您总是可以将.order('random()')添加到关系中:ar=Model.where(...).where(...).order('random()')您甚至可以将其添加为范围:classModel有几点需要注意:PostgreSQL和SQLite使用random(),MySQL使用rand(),我不确定其他数据库。ORDERBYrandom()在数据库中可能非常昂贵,因此您不想使用它,除非

ruby - 在 RSpec 测试中模拟 ActiveRecord 关系行为

我在测试时遇到过这个问题。假设我有两个模型,User和Post,其中userhas_many:posts。我正在尝试指定包含如下内容的代码块:user=User.find(123)post=user.posts.find(456)我知道如何模拟User.find和user.posts部分。user.posts模拟返回一个Post对象数组。当它到达.find(456)部分时,一切都崩溃了,并出现noblockgiven异常。所以我的问题是:作为user.postsmock的结果我要返回什么,以便.find(456)方法对其起作用?User.first.posts.class说它是Arra