草庐IT

typeorm-activerecord

全部标签

ruby - 同时具有 ActiveResource 和 ActiveRecord 的 Rails 审计系统

我有一个包含ActiveRecord和ActiveResource模型的大型项目。我需要使用这些模型实现用户事件的日志记录,还需要记录模型属性的更改(保存对象状态或类似的东西)。用户或cronrake任务可以进行更改。我还必须能够按日期、任何字段等搜索任何数据例如,生成带有上次事件的可读消息也很好UserBobchangehispasswordto*andemailto**at2011-08-1208:12StaffJeffaddednewpartner:Companynameat2011-08-1208:13AdminJackdeletedproduct:Productnameat2

ruby-on-rails - Rails 3 ActiveRecord 抽象对象

我正在尝试实例化抽象AR类的对象以用于测试目的。模型的定义如下:classBasic当我尝试Basic.new时,我得到:"Mysql2::Error:Table'project_development.basics'doesn'texist"这是正常行为吗?即使没有(显然不可能)持久性,抽象AR类是否也不会被实例化?在Rails3.0.4/Mysql20.2.6中使用1.9.2-p136编辑:事实证明错误是由列定义引起的,在抽象模型的情况下无法从数据库中获取列定义。classBasic像魅力一样工作。 最佳答案 这是正常行为。抽象

ruby-on-rails - ActiveRecord::Base 上的 alias_method 导致 NameError

我有一个直接从ActiveResource::Base继承的模型,我正在尝试为记录表中的大部分列运行alias_method,但结果是一个NameError:NameError:undefinedmethodaddress_line_1'forclassLeadImport::Base'但我可以访问属性:LeadImport::Base.new.address_line_1#=>nil(noterror)我的类(class)有一个名为address_line_1的表列,所以我没有看到问题。classLeadImport::Base规范:Ruby1.8.7、Rails2.3.8

ruby-on-rails - ActiveRecord 选择列除外

有没有一种方法可以指定选择ActiveRecord中的所有列,只有少数列除外。例如,对于用户,我不想选择他们的密码哈希或他们的电子邮件。这是可能的还是我必须手动硬编码所有列?谢谢 最佳答案 写一个像这样的范围defselect_withoutcolumnsselect(column_names-columns.map(&:to_s))end 关于ruby-on-rails-ActiveRecord选择列除外,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - ActiveRecord:我可以复制关联吗?

有没有办法将一个模型的关联复制到另一个...template_model=MyModel.find(id)new_model=template_model.clonenew_model.children...这样我就可以将子项从模板复制到新模型?(实际上,此代码将子项从模板移动到新模型)。我知道我可以手动循环,但有没有更简洁的方法?谢谢 最佳答案 问题是您正在克隆模板,而不是克隆它的子项。尝试类似的东西:template_model=MyModel.find(id)new_model=template_model.clonenew_

ruby-on-rails - 检查 ActiveRecord 查找是否返回结果

我正在尝试检查查找方法是否返回结果。我的查找方法如下:post=Post.find(:all,:conditions=>{:url=>params['url']},:limit=>1)检查post是否包含结果的好方法是什么? 最佳答案 find:all如果没有返回任何行,则返回一个空数组([]),因此您可以这样使用它:post=Post.find(:all,:conditions=>{:url=>params['url']},:limit=>1)unlesspost.empty?#dosomething...end顺便说一句,如果您

ruby-on-rails - Rails 将参数/参数传递给 ActiveRecord 回调函数

我的一个AR模型中有以下代码片段:after_update:cache_bust模型中的cache_bust方法接受一个参数(bool值),默认将其自身的值设置为false。如何从上面定义的ActiveRecord回调中将true传递给模型中的这个方法?例如:after_update:cache_bust(true)不起作用,因为它是一个符号,我如何将true传递给方法的参数? 最佳答案 Therearefourtypesofcallbacksacceptedbythecallbackmacros:Methodreferences(

sql - ActiveRecord::StatementInvalid。 PG错误

我正在尝试使用Project.find(id)从Project模型中找到一个项目,但它给了我ActiveRecord::StatementInvalid错误完整跟踪-PG::Error:ERROR:preparedstatement"a1"alreadyexists:SELECTCOUNT(*)FROMpg_classcLEFTJOINpg_namespacenONn.oid=c.relnamespaceWHEREc.relkindin('v','r')ANDc.relname=$1ANDn.nspname=ANY(current_schemas(false))/home/deploy

ruby-on-rails - 如何使用 ActiveRecord 连接设置事务隔离级别?

我需要以一种跨数据库(至少是SQLite、PostgreSQL、MySQL)可移植的方式在每个事务的基础上管理事务隔离级别。我知道我可以手动完成,就像那样:User.connection.execute('SETSESSIONTRANSACTIONISOLATIONLEVELSERIALIZABLE')...但我希望是这样的:User.isolation_level(:serializable)do#...end 最佳答案 此功能由ActiveRecord本身支持:MyRecord.transaction(isolation::re

ruby-on-rails - Rails - ActiveRecord 使用 :dependent => :destroy on condition

根据条件销毁对象的所有依赖项的最佳/DRY方法是什么。?例如:classWorker:destroyhas_many:coworkers,:dependent=>:destroyhas_many:company_credit_cards,:dependent=>:destroyend条件是销毁:ifself.is_fired?#Destroydependantsrecordselse#DonotDestroyrecordsend有没有办法在:dependent条件下使用Proc。我已经找到了单独销毁依赖项的方法,但这对于进一步的关联来说不是DRY和灵活的,注意:我编造了例子..不是实际