草庐IT

ActiveRecord

全部标签

ruby-on-rails - Rails 3.2 Postgres 保存错误 "ActiveRecord::StatementInvalid: PG::Error: ERROR: Syntax error near ' T' 在位置 5"

当我尝试将特定类保存到数据库时,我的应用开始抛出错误。我不确定到底是什么原因导致这种情况开始发生-过去几天我一直遇到各种数据库问题....无论如何,我的模型似乎工作正常(它正在正确计算所有before_save值),但随后它尝试保存到数据库并爆炸。SQL(0.8ms)INSERTINTO"portfolios"("correlation_matrix","created_at","data","mean_return","std_dev","updated_at","weights")VALUES($1,$2,$3,$4,$5,$6,$7)RETURNING"id"[["correla

ruby-on-rails - ActiveModel - 查看 - Rails 中的 Controller 而不是 ActiveRecord?

我正在尝试对我的模型使用ActiveModel而不是ActiveRecord,因为我不希望我的模型与数据库有任何关系。下面是我的模型:classUserincludeActiveModel::Validationsvalidates:name,:presence=>truevalidates:email,:presence=>truevalidates:password,:presence=>true,:confirmation=>trueattr_accessor:name,:email,:password,:saltdefinitialize(attributes={})@name

ruby-on-rails - 如何恢复/撤消对 Activerecord 对象的本地更改?

有没有办法撤消/恢复对Activerecord对象的任何本地更改。例如:user=User.firstuser.name#"Fred"user.name="Sam"user.name_was#"Fred"user.revertuser.name#"Fred"我知道我可以执行user.reload但我不必访问数据库来执行此操作,因为旧值存储在对象的状态中。最好是Rails3解决方案。 最佳答案 如thisanswer中所述Rails4.2在ActiveModel::Dirty中引入了restore_attributes方法:user=

ruby-on-rails - Rails 4 按模型方法求和

在我的应用程序中,我有一个User模型,带有goal_ytd方法,执行一些计算。在Controller中,我有一个变量@users那可能是User或ActiveRecord::Relation的users,我想总结所有@users的goal_ytd我的第一个倾向是:@users.sum(&:goal_ytd)因为使用sum在这两种情况下都抛出了弃用警告在ActiveRecord::Relation上将在Rails4.1中消失。因此,我将代码更改为:@users.to_a.sum(&:goal_ytd)然后抛出一个NoMethodError因为,在某种情况下,@users由@users=

ruby - 请安装 postgresql 适配器 : `gem install activerecord-postgresql-adapter`

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:HowtohandleRubyonRailserror:“Pleaseinstallthepostgresqladapter:`geminstallactiverecord-postgresql-adapter'”我正在尝试让Redmine与postgres一起工作。在我的日志中,我不断看到。Pleaseinstallthepostgresqladapter:`geminstallactiverecord-postgresql-adapter`在谷歌搜索之后,每个人都说你需要做geminstallpg。但是当

ruby-on-rails - 使用 define_method 动态定义 setter 方法?

我使用大量迭代来定义模型中的便捷方法,例如:PET_NAMES.eachdo|pn|define_method(pn)do......end但我从来没有能够动态定义setter方法,即:defpet_name=(name)...end像这样使用define_method:define_method("pet_name=(name)")do...end有什么想法吗?提前致谢。 最佳答案 这是一个在用于扩展类的模块中使用define_method的完整示例:moduleVerboseSetterdefmake_verbose_sette

ruby-on-rails - 在没有 ActiveRecord 的情况下使用 Ruby on Rails

我一直在考虑将我的Web项目从使用PHP切换到RubyonRails,而我最关心的一件事是使用ActiveRecordforRails。在我看来,强烈鼓励使用ActiveRecord,而直接编写SQL似乎不受欢迎。在查看了几个项目后,我还没有看到一个真正在其中使用SQL的项目。我还没有在ActiveRecord上出售,主要是因为它需要学习一些看起来不像直接SQL那样强大的东西,例如有没有一种简单的方法可以使用ActiveRecord的groupby和having子句进行嵌套查询,或者我必须跳过箍才能这样做吗?有没有人在没有ActiveRecord的情况下使用过Rails?如果是,您这样

ruby-on-rails - Rails 5 SQL 注入(inject)

我已经在各种SO线程、指南等上阅读了一段时间...但所有答案都是相互矛盾和矛盾的。好像有很多类似的方法,而且很多答案都说使用不同的方法。清理sanitize_conditionssanitize_sqlsanitize_sql_arraysanitize_sql_for_assignmentsanitize_sql_for_conditionssanitize_sql_hashsanitize_sql_hash_for_assignmentsanitize_sql_hash_for_conditionssanitize_sql_like我正在尝试编写一个“原始查询”适配器,让我可以运行

sql - 在 ActiveRecord 中存储序列化哈希与键/值数据库对象的优缺点?

如果我有几个对象,每个对象基本上都有一个Profile,我用什么来存储随机属性,有什么优缺点:在记录列中存储序列化哈希,对比存储一组属于主对象的键/值对象。代码假设您有这样的STI记录:classBuilding:profilableendclassOfficeBuilding每个has_one:profile选项1.序列化哈希classSerializedProfiletruedo|t|t.string:namet.string:websitet.string:emailt.string:phonet.string:typet.text:settingst.integer:profi

ruby-on-rails - 在多个数据库上使用 ActiveRecord

我正在编写一个工资单系统,它将与一个预先存在的系统集成。原来的系统有一个主数据库,负责用户管理和一些全局配置,下面有多个数据库,每个数据库结构相同,基本上每个数据库都是一个公司的工资数据库,所有这些都绑定(bind)到主数据库,因为它属于一个父数据库公司拥有许多子公司,每个子公司都有自己的人力资源部门。我想知道是否有任何方法可以基于cookie或存储他们希望连接的公司的其他方法,使用前置过滤器根据他们的输入动态更改ActiveRecord的目标数据库?这是一个例子:用户A登录网站,页面加载用户有权访问的可用公司,然后用户将选择一家公司,他们在该公司拥有管理员权限,他们添加一名员工,然后