草庐IT

Relation

全部标签

ruby-on-rails - ActiveRecord 和 ActiveRecord::Relation 对象之间的区别

我已经搜索过但无法找到ActiveRecord和ActiveRecord::relation对象之间区别的简要说明。我知道ActiveRecord是通过类似的东西找到的单个对象User.find(1)ActiveRecord::Relation是类似对象的数组,通过类似的方式查找User.where(id:1)我正在寻找它们在查询执行或对它们的深入解释方面的区别,因此它将清楚其背后的整个概念。提前致谢! 最佳答案 ActiveRecord::Base的一个实例是一个对象,表示您的数据库的特定行(或者可能保存到数据库中)。而Activ

ruby-on-rails - Ruby on Rails - n :m many-to-many relation

我有两个对象,即食谱和配料。我使用创建了它们railsgeneratescaffoldingredientid:integername:stringrailsgeneratescaffoldrecipeid:integername:string我也想用n:m关系(多对多)创建它们。我该怎么做?我应该创建一个不同的脚手架吗?谢谢。 最佳答案 不,您需要通过生成迁移来创建连接表。railsgmigrationingredients_recipesingredient_id:integerrecipient_id:integer然后,您可

ruby-on-rails - 如何解决#<Book::ActiveRecord_Relation:0x007fb709a6a8c0> 的未定义方法 `to_key'?

我遇到了未定义方法`to_key'的问题这是我的books_controller.rbclassBooksController和我的索引页如下。index.html.erb......现在当我要访问索引页面时出现如下错误。undefinedmethod`to_key'for# 最佳答案 index通常返回一个集合。事实上,您的Controller符合要求。但是,您的View试图为其定义一个表单。正如您所发现的,这不会成功。表单适用于实体,而不适用于集合。该错误在您看来以及您希望如何处理index。

ruby-on-rails - rails : Find rows without connection in HABTM relation

我有两个模型,Users和Leads与HABTM关系相关:classLead我现在如何才能只获得那些与用户无关的线索?提前致谢! 最佳答案 您正在寻找的是antijoin.有三种标准方法可以实现这一点,使用空左外连接使用带有NOT和IN关键字的子查询的where子句使用带有NOT和EXISTS关键字的where子句基本上,EXISTS关键字将检查子查询是否返回任何行并将其报告为匹配项,NOT显然会否定真正的匹配项。这是我的首选方式(使用NOT&EXISTS)classUser这是一个使用arel的非SQL方法classUserher

ruby - Stub ActiveRecord::Relation with ActiveRecord 对象

我不是在测试Rails应用程序。只是解决这个问题。我正在测试一个连接到相对活跃的服务器的库,按时间戳限制记录。这些返回的记录随着时间​​的推移而变化,使得测试其他限制变得更加复杂。我需要stubActiveRecord::where方法来返回我自己与我创建的对象的自定义关系,以满足我需要的标准。有点像relation=double(ActiveRecord::Relation)relation.stub(:[]).and_return([MyClass.new(...),MyClass.new(...),...])MyClass.stub(:where).and_return(rela

ruby - 添加两个 ActiveRecord::Relation 对象

这个问题在这里已经有了答案:CombinetwoActiveRecord::Relationobjects(10个答案)关闭8年前。如何将两个关系加在一起?当我尝试+运算符时,它返回一个数组。但我需要它来返回关系。谢谢,麦克

ruby-on-rails - PGError : ERROR: relation "table_name" does not exist

我正在尝试将一个简单的应用程序推送到heroku并运行:herokurakedb:migrate但是我得到以下错误:rakeaborted!PGError:ERROR:relation"posts"doesnotexist:SELECTa.attname,format_type(a.atttypid,a.atttypmod),d.adsrc,a.attnotnullFROMpg_attributeaLEFTJOINpg_attrdefdONa.attrelid=d.adrelidANDa.attnum=d.adnumWHEREa.attrelid='"posts"'::regclass

ruby-on-rails - ruby rails : Properly creating a model instance that has relation to multiple models

假设我有一个独立的用户模型和服务模型。我还有一个订单模型,用于保存用户为某项服务创建的订单。我想知道如何在Rails中正确创建订单条目。以下是我将如何创建一个订单条目,如果它只引用一个其他模型,比如用户。@order=current_user.orders.build(params[:order])@order.save现在,如果订单涉及多个模型(用户和服务),我该怎么做?假设Order模型具有user_id和service_id属性,并且所有模型对象都正确标记了belongs_to和has_many关系。 最佳答案 @order=

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 - pg_dump : [archiver (db)] query failed: ERROR: permission denied for relation abouts

我正在尝试转储我的pgdb但遇到这些错误请建议pg_dump:[archiver(db)]queryfailed:ERROR:permissiondeniedforrelationaboutspg_dump:[archiver(db)]querywas:LOCKTABLEpublic.aboutsINACCESSSHAREMODE 最佳答案 您正在执行pg_dump的用户没有公共(public)模式的权限。如果允许则添加权限:GRANTUSAGEONSCHEMApublicTO;GRANTSELECTONALLTABLESINSCH