草庐IT

activerecord-import

全部标签

sql - 如何模拟ActiveRecord Model.count.to_sql

我想显示一个计数中使用的SQL。但是,Model.count.to_sql将不起作用,因为count返回一个没有to_sql方法的FixNum。我认为最简单的解决方案是这样做:Model.where(nil).to_sql.sub(/SELECT.*FROM/,"SELECTCOUNT(*)FROM")这会创建与Model.count中使用的SQL相同的SQL,但它是否会导致进一步的问题?例如,如果我添加一个复杂的where子句和一些连接。有更好的方法吗? 最佳答案 你可以试试Model.select("count(*)asmode

ruby-on-rails - 使用 PostgreSQL 适配器限制 ActiveRecord 迁移 5.0 中的文本列

我的迁移看起来像这样classCreateQuestionings现在,当我运行$rakedb:migrate:reset时,在我的db/schema.rb中看不到限制:create_table"questionings",force::cascadedo|t|t.text"body",null:falseend我做错了吗还是这是一个错误?顺便说一下,我使用的是rails5.0.0.beta3和ruby​​2.3.0p0。 最佳答案 t.text在PostgreSQL和textdoesn'tallowforsizelimits中生成

ruby-on-rails - 如何使 ActiveRecord::Schema.define 不登录到标准输出?

我在文档中看不到这个,但我认为这是一个已解决的问题。我在Rails之外使用ActiveRecord,我的脚本加载了从另一个应用程序转储的schema.rb。我想加载此模式而不将迁移输出转储到标准输出,但替换ActiveRecord::Base.logger不会关闭它。我应该覆盖什么来阻止噪音? 最佳答案 技巧显然在ActiveRecord::Migration中:ActiveRecord::Migration.verbose=false这使得迁移不会将信息输出到$stdout。有一个名为.suppress_messages的便捷包装

ruby - ActiveRecords 选择(:id). 收集与采摘(:id) methods: Why is pure AR "pluck" slower?

我正在尝试从我的文章模型中获取所有ID。我可以通过两种方式做到这一点:Article.select(:id).collect{|a|a.id}ArticleLoad(2.6ms)SELECT"articles"."id"FROM"articles"或2.2.1:006>Article.pluck(:id)(4.3ms)SELECT"articles"."id"FROM"articles"什么给了?为什么AR比Ruby版本慢?即使我对Ruby方法进行基准测试,它似乎也更快:Benchmark.measure{Article.select(:id).collect{|a|a.id}}Art

ruby-on-rails - Rails ActiveRecord 条件回调问题

ruby2.1.8rails3.2.18我试图在仅当特定属性已更改的情况下保存记录时运行回调。例如before_save:do_the_thing,if::my_attr_changed?但是,当我更改my_attr并保存时,do_the_thing没有得到叫。然而,如果我做完全相同的事情,但是:before_save:do_the_thingdefdo_the_thingputsmy_attr_changed?end它将“true”输出到日志中。这里比较困惑。任何帮助表示赞赏。谢谢。 最佳答案 只需将它移到lambda中befor

ruby-on-rails - Ruby Gem 开发 - 如何使用 ActiveRecord?

我目前正在尝试开发我的第一个rubygem,但我已经陷入困境。我使用“bundlegem”命令来创建基本结构并阅读了一些教程,但我找不到的是如何集成ActiveRecord。我在哪里创建迁移?我是在lib文件夹中还是在根文件夹中创建“db/migrations”文件夹?我必须在Rakefile中做任何事情吗(我发现一些问题的答案是“你必须创建自己的[my_gem]:db:migrate”或类似的东西。)我所需要的只是一种创建gem的方法,它定义了ActiveRecord模型(当然包括迁移),然后可以由Rails应用程序使用。如有任何帮助,我们将不胜感激!你好,弗洛

ruby - 有没有一种干净的方法来测试 Rspec 中的 ActiveRecord 回调?

假设我有以下ActiveRecord类:classToastMitten是否有一种干净的方法来测试:brush_off_crumbs是否已设置为before_save回调?我所说的“干净”是指:“没有实际保存”,因为它很慢我不需要测试ActiveRecord是否正确处理before_save指令;我需要测试我是否正确地告诉它在保存之前要做什么。“没有通过未记录的方法进行黑客攻击”我找到了满足标准#1但不满足标准#2的方法:it"shouldcallhavebrush_off_crumbsasabefore_savecallback"do#undocumentedvoodoobefore

ruby-on-rails - 了解 Rails 中的简单 ActiveRecord 更新

我刚刚深入研究ActiveRecord,但未能找到我的问题的答案。如果我正在更新对象的属性然后调用save()...ActiveRecord是否仅在新值与旧值不同时才保存到数据库?假设我做了这样的事情:thing_to_update=Thing.find_or_create_by_code(some_code)ifthing_to_update.name!=some_namething_to_update.update_attribute(:name,some_name)end如果不需要的话,我不想对数据库进行额外的调用,因为我可能不得不更新很多对象。我试图通读文档,但它没有提及任何关

ruby-on-rails - ActiveRecord 中的零个或一个关联

我正在编写一个RubyonRails应用程序,它有两个模型——用户和农场。如果用户的farmer字段设置为true,则该用户被视为农民。但是,没有针对农民的单独类(class)。一个用户可以有一个农场,也可以没有。(我相信这称为零或一关系)。如果我把:has_one:farm在用户模型中belongs_to:user在农场模型中,这将在用户和农场之间建立一对一的关系,意味着每个用户都有一个农场。如果我这样做,每个用户都会有一个农场,这没有多大意义,因为有些用户无法拥有农场。简而言之,我希望用户只有在其farmerbool值设置为true时才能拥有农场。否则,这种关系不应该存在。他们是否

ruby-on-rails - JSON 到 ActiveRecord(反序列化)

我正在使用Ruby、Grape和ActiveRecord构建一个网络API。来自ASP.NETWebAPI我习惯于从JSON到类对象的自动模型绑定(bind),然后可以使用EntityFramework保存。我一直在搜索一下,看看在使用ActiveRecord时是否有类似的东西,但没有发现任何让我觉得我遗漏了一些非常明显的东西。将JSON反序列化为ActiveRecord模型的最佳方法是什么?更新Matts回答对简单类型非常有效,但是当我有关联时,我收到以下错误:ActiveRecord::AssociationTypeMismatch:Connector(#7029771166878