草庐IT

activerecord-postgis-adapter

全部标签

ruby-on-rails - Cucumber BDD for RAILS/ActiveRecord - 通过填充数据库层来加速慢速测试?

我公司正在使用Cucumber适用于中等大型RAILS应用程序的BDD测试框架。它很慢。狗慢。仅我正在处理的一个cucumber就需要30到40秒才能运行,并且有几十个不同的测试文件。运行整个过程大约需要一个多小时。仔细研究一下,有大量重复的数据库工作,但总数据量非常小。例如,我看到像这样的慢语句:GivenIhaveallthediscussionthreadsfor"fakeuser47"这需要1000多毫秒。它所做的唯一一件事就是从磁盘上的文件中取出几十行库存夹具数据,然后一次一行地将其加载到数据库中。数据量不是很大,最多几KiB。但是一旦你将所有ActiveRecord处理的开

ruby-on-rails - ActiveRecord 加入 : integer columns converted to strings

我有一个名为Article的模型,我正在加入TwitterShare,如下所示:articles=Article.joins("LEFTOUTERJOINtwitter_sharesONarticles.id=twitter_shares.article_id").where("articles.id=?orarticles.id=?",27165,5632).select("articles.id,twitter_shares.user_id")当我取回文章并检查返回的Article模型时,它以字符串形式返回user_id,即使twitter_shares表中的列类型是整数。为什么是

ruby - 从 ActiveRecord 迁移中输出 SQL 而不执行它(不是 rails!)

有很多与此类似的问题,讨论将rails插件作为一种解决方案-但我没有使用rails,请继续阅读以获取更多信息我在sinatra项目中有一个Rakefile,它允许我rakedb:migrate。它会完美地完成我的迁移,但我想传递一个标志(或编写一个新的rake任务),它做同样的事情,但将SQL输出到STDOUT并且不提交对数据库的更改。有谁知道如何做到这一点?我的第一个想法是尝试使用ActiveRecord日志记录,看看我是否可以完全取出SQL,但是那行不通!有什么想法吗?namespace:dbdotask:migrate_sqldorequire'logger'ActiveReco

sql - ActiveRecord 查找子资源的所有子资源

我有Projecthas_many:locations和Locationshas_many:comments,以及Projecthas_many:plans和Planhas_many:comments。如何选择属于一个项目的所有可评论资源的所有评论?如果相关的话,我正在使用ActiveAdmin和ActiveAdmin::Comment。我试过的:p=Project.firstcomments=p.locations.map(&:comments).flatten+p.plans.map(&:comments).flatten但是是否有ActiveRecord或Rails方法可以做到这

sql - ActiveRecord has_many 通过多态 has_many

看来rails仍然不支持这种类型的关系并抛出ActiveRecord::HasManyThroughAssociationPolymorphicThroughError错误。我该怎么做才能实现这种关系?我有以下联想:Users1..nArticlesCategoriesn..nArticlesProjects1..nArticles这是订阅模式Subscription1..1UserSubscription1..1Target(polymorphic(Article,CategoryorUser))而我需要根据user#subscriptions通过Subscription#targe

ruby-on-rails - ActiveRecord::Serializer 中的条件侧载数据(基于 Controller 操作)

我在Rails和构建应用程序方面没有太多经验。我尝试使用ActiveModel::Serializers构建API。为特定事件操作有条件地加载数据的最佳方法是什么?我是否必须通过在每次调用时发送查询参数来做到这一点,或者我可以设置includes:trueonlyforspecificactionoranyothersuggestion?classEventsController[:index,:show]before_filter:locate_collection,:only=>:indexskip_before_filter:verify_authenticity_token,:

sql - 在 Rails 3/ActiveRecord 中构建 LIKE 查询时转义 %% 的正确方法

我想将url字段与url前缀(可能包含百分号)相匹配,例如.where("urlLIKE?","#{some_url}%").什么是最Rails的方式? 最佳答案 从Rails版本4.2.x开始,有一个名为sanitize_sql_like的事件记录方法。因此,您可以在模型中执行如下搜索范围:scope:search,->search{where('"accounts"."name"LIKE?',"#{sanitize_sql_like(search)}%")}并像这样调用作用域:Account.search('Test_%')生成

ruby-on-rails - 在 Rails/ActiveRecord 3 中,如何更改 MySQL 的默认主键类型?

在Rails3中,如何将默认主键类型更改为BIGINTUNSIGNEDNOTNULLAUTO_INCREMENTPRIMARYKEY就我而言,我只对MySQL感兴趣。对于Rails2,您可以查看“如何在Rails中使用长ID?”的答案。1然而,在Rails3中,这会引发错误。我不确定那是因为该类不再使用,还是代码需要放在同一个地方。您可以在active_record/connection_adapters/mysql_adapter.rb中看到NATIVE_DATABASE_TYPES常量仍然被定义。在Rails3中实现相同效果的正确方法是什么? 最佳答案

ruby-on-rails - Rails - PostGIS + postgis_adapter 几何问题

我使用postgis_adapter以及基于Ruby1.9.2的PostgreSQL9.0.4、PostGIS1.5.2和Rails3.1.0。如postgis_adapterREADME中所述,我尝试执行Model.create(:geom=>Point.from_x_y(10,20))Postgres响应ERROR:parseerror-invalidgeometryHINT:YoumustspecifyavalidOGCWKTgeometrytypesuchasPOINT,LINESTRINGorPOLYGON创建的GeoRuby对象如下所示:#希望有人有想法。

ruby-on-rails - RSpec 失败是因为它认为 ActiveRecord 对象不相等

非常简单的规范...@post.user.should==@user尽管这两个对象除了它们的object_id之外在所有方面都相同,但规范失败了。如果ActiveRecord对象的id相同,则它们应该等于(==)。这些对象是使用factory_girl创建的。我已经确认这两个对象都不是“.new_record?”。比较@post.user.id和@user.id的效果。更重要的是行为不一致。这些测试一直有效,但现在尽管没有任何更改,但它们还是失败了。rails3.1rspec-2.6factory_girl-2.0.5factory_girl_rails-1.1.0jruby1.6.4