jjzjj

column-count-limit

全部标签

sql - Rails SQL COUNT N+1 效率低下

我有一个博客。在我的索引页面上,我拉入了所有博客文章。对于每篇博客文章,我都会计算该文章的评论数。这会导致N+1问题。我的查询如下所示:SELECT"blog_posts".*FROM"blog_posts"WHERE("blog_posts"."published"='t')ORDERBYpublished_atDESCSELECT"users".*FROM"users"WHERE("users"."id"IN(1,2,3))SELECTCOUNT(*)FROM"blog_comments"WHERE("blog_comments".blog_post_id=10)SELECTCOU

ruby-on-rails - rails : How do I check if a column has a value?

我怎样才能做到这一点?...Cell:...我想测试代理是否有手机号码,如果有,显示条件中的内容。我目前拥有的似乎不起作用;它只显示“单元格:”。想法? 最佳答案 这是你要求的:Cell:细胞?无论cell是nil还是空字符串,方法都有效。Rails为所有ActiveRecord属性添加了类似的功能。这看起来会好一点:Cell:问号和冒号构成了一个快速的“if?then:else”语句。上面代码中有两个问号是因为一个是方法名单元格的一部分?另一个是if/then/else构造的一部分。

ruby-on-rails - Array.count with block 不返回正确答案

我有一个从数据库调用创建的赋值对象数组:@assignments=@player.assignments我想用这个来计算它们:@assignments.count{|x|x.sets==0.0}这应该计算0.0组的作业数。但是,这总是返回@assignments中的对象总数。我查过了@assignments.each{|x|putsx.sets==0.0}并非在所有情况下都返回true。有什么线索吗?编辑>@assignments.map(&:sets)=>[35.0,120.0,0.0,0.0,0.0,0.0,0.0,12.0,75.0,0.0,0.0,0.0,0.0]

ruby-on-rails - 预期 #count 已更改为 1,但未获得 block

我正在测试我的model方法,该方法返回一个Account对象。我正在检查我的表是否插入了一个新的行并且我的模型反射(reflect)了它的计数。下面是我的规范。it"cancreateanaccount"docreate_account=Account.create(account:acc)create_account.shouldchange(Account,:count).by(1);end我得到的错误8)AccountcancreateanaccountFailure/Error:create_account.shouldchange(Account,:count).by(1)

ruby-on-rails - 事件记录 :includes with limit

我有一个包含很多图片的文章表图像为每篇文章排序,第一个排序的图像旨在作为文章缩略图。在文章Controller索引方法中,我目前正在执行以下操作以限制为2个事件记录查询;@articles=Article.where(:active=>true).includes(:images)访问缩略图:#articlemodeldefthumbself.images.firstifself.imagesend问题是这只有2个查询,但如果每篇文章有10张图片并且我在每个页面上有50篇文章,那么我将500个图像行加载到内存中。在事件记录中是否有更有效的方法。希望不必使用find_by_sql

ruby-on-rails - 在 Rails 3 中使用 update_columns?

在Rails3中有更短的方法吗?user.update_column(:attribute1,value1)user.update_column(:attribute2,value2)user.update_column(:attribute3,value3)user.update_column(:attribute4,value4)我试过update_columns但它只在Rails4中可用。感谢您的帮助。 最佳答案 这是Rails3.x的解决方法:User.where(id:user.id).update_all(attribu

ruby-on-rails - ruby rails : adding columns to existing database

我收到一个错误:SQLite3::SQLException:nosuchcolumn:ideas.list_id:SELECT"ideas".*FROM"ideas"WHERE"ideas"."list_id"=2但是我加了t.integer:list_id到我的数据库迁移文件:classCreateIdeas这给了我这个:classCreateIdeas然后我输入rakedb:migrate知道为什么我会收到一条错误消息说没有专栏吗?我对RoR还是陌生的。我必须以其他方式添加一列吗?谢谢 最佳答案 正如Speransky所建议的,

ruby-on-rails - rails 4 : Add Multiple Columns to Existing Table

我知道如何向现有表格中添加一列。现在我必须向现有表中添加许多列。是否有更短的方法:add_col1_col2_col3_col4_.._coln_to_tablescol1:integercol2:integeretc...我是否必须对我必须添加的所有额外列执行上述操作? 最佳答案 没有必要。你可以做假设TableName是用户railsgmigrationAddColumnsToUsercol1:integercol2:integer..etc. 关于ruby-on-rails-rai

ruby-on-rails - 脚手架 ActiveRecord : two columns of the same data type

另一个基本的Rails问题:我有一个数据库表,需要包含对特定数据类型的两个不同记录的引用。假设示例:我正在制作视频游戏数据库。我有一张“公司”表。我想为每个“视频游戏”条目指定一个开发者和一个发布者。我知道如果我想拥有一家公司,我可以这样做:script/generateVideogamecompany:references但我需要同时拥有这两家公司。我宁愿不使用连接表,因为给定的数据类型只能有两个,我需要它们是不同的。看起来答案应该很明显了,但是我在网上到处都找不到。 最佳答案 只是为了稍微整理一下,在您的迁移中,您现在还可以:c

sql - GROUP BY 和 COUNT 使用 ActiveRecord

引用这个:IsthereanydifferencebetweenGROUPBYandDISTINCTGivenatablethatlookslikethis:name------barrydavebilldavedavebarryjohnThisquery:SELECTname,count(*)AScountFROMtableGROUPBYname;Willproduceoutputlikethis:namecount-------------barry2dave3bill1john1对于ActiveModel使用COUNT执行GROUPBY的正确Rails约定是什么?