草庐IT

activerecord-sqlserver-adapter

全部标签

ruby-on-rails - 使用 `ActiveRecord with_connection do` 和 ActionController::Live 时出现线程错误

主要编辑:自从最初发现此问题后,我已将其缩减为以下内容。我认为现在这是对问题的略微更精确的描述。因此,对OP的评论可能并不完全相关。编辑在rails/puma项目中发布的轻微修改版本:https://github.com/rails/rails/issues/21209,https://github.com/puma/puma/issues/758编辑现在用OSX和Rainbows复制总结:当使用Puma并运行长时间运行的连接时,我一直收到与跨线程的ActiveRecord连接相关的错误。这在消息中表现出来,例如消息类型0x##空闲时从服务器到达和锁定(崩溃)的服务器。设置:Ubunt

ruby-on-rails - 了解 establish_connection 在 ActiveRecord 中的工作原理

此代码取自ActiveRecord2.3.14的gem类ConnectionHandlerdefestablish_connection(name,spec)@connection_pools[name]=ConnectionAdapters::ConnectionPool.new(spec)end似乎每次ruby​​在模型上调用establish_connection时,它都会创建一个新的连接池。我的问题:如果我有5个模型使用establish_connection连接到同一个数据库,Rails是否足够智能以选择一个已经存在的池而不是创建一个具有相同连接凭据的新池?如果我的5个模型是

ruby-on-rails - ActiveRecord 查询中的 “includes” 和 “preload” 有什么区别?

我正在努力寻找ActiveRecord对象的includes()和preload()的比较。谁能解释一下区别? 最佳答案 Rails有两种方法可以避免n+1问题。一个涉及创建一个基于大连接的查询以拉入您的关联,另一个涉及为每个关联进行单独的查询。当您执行includes时,rails会决定为您使用哪种策略。它默认使用单独的查询方法(预加载),除非它认为您正在使用条件或订单中关联的列。因为这只适用于joins方法,所以改用它。Rails的启发式方法有时会出错,或者您可能有特定的原因偏爱一种方法而不是另一种方法。preload(及其配套

ruby-on-rails - rails : Overriding ActiveRecord association method

有没有办法覆盖ActiveRecord关联提供的方法之一?例如,我有以下典型的多态has_many:throughassociation:classStory:taggablehas_many:tags,:through=>:taggings,:order=>:nameendclassTag:destroyhas_many:stories,:through=>:taggings,:source=>:taggable,:source_type=>"Story"end您可能知道,这会向Story模型添加一大堆关联方法,例如标签、标签我如何着手覆盖这些方法之一?特别是tagsdeftags调

ruby-on-rails - 在 Rails/ActiveRecord 列名中使用问号字符

为了与Ruby在bool方法中使用问号的习惯用法保持一致(例如person.is_smart?),我想对Rails中的ActiveRecord字段执行相同的操作:railsgeneratemodelPersonis_smart?:boolean我实际上并没有运行上面的语句。我假设数据库字段中不能有问号。Rails会适本地处理这个问题吗?最好的做法是简单地在模型上留下问号吗?使用Rails3.2.8 最佳答案 如果有名为'smart'的字段,Rails会自动生成方法smart?。 关于ru

ruby-on-rails - 从 ActiveRecord 对象中提取两个属性的快捷方式?

是否有更短的方法来执行以下操作(@user.employees.map{|e|{id:e.id,name:e.name}}#=>[{id:1,name:'Pete'},{id:2,name:'Fred'}]用户has_many员工。这两个类都继承自ActiveRecord::Base。上面有两点我不喜欢它在映射之前将员工加载到内存中,它很冗长(我猜是主观的)。有没有更好的办法? 最佳答案 更新:查看@jamesharker的解决方案:从ActiveRecord>=4,pluck接受多个参数:@user.employees.pluck

ruby-on-rails - ruby - ActiveRecord::ConnectionNotEstablished

我是Ruby的新手,一直在关注“RubyOnRails3教程-通过示例学习Ruby-MichaelHartl着”这本书。我目前在讨论静态页面的第3章。在本章中,我在提示符中输入了以下命令:railsgeneratecontrollerPageshomecontact一切正常。然后这本书将我引导至http://localhost:3000/pages/home。当我将浏览器指向那里时,我收到以下错误。ActiveRecord::ConnectionNotEstablishedActiveRecord::ConnectionNotEstablishedRails.root:/home/ra

ruby-on-rails - 如何在我的 Rails 应用程序中测试 ActiveRecord::RecordNotFound?

我的Controller中有这段代码,我想通过功能测试来测试这段代码。raiseActiveRecord::RecordNotFoundif@post.nil?我应该使用哪种断言方法?我使用内置的rails2.3.5测试框架。我用这段代码试过了:test"shouldreturn404ifpagedoesn'texist."doget:show,:url=>["nothing","here"]assert_response:missingend但这对我不起作用。得到这个测试输出:test_should_return_404_if_page_doesn't_exist.(PageCont

ruby-on-rails - Rails 4,使用 ActiveRecord 的原始查询

目前有没有办法在Rails4.0.0.beta1中使用ActiveRecord执行原始SQL选择查询?我看到ActiveRecord::Base.execute不再存在。正确的做法是什么? 最佳答案 在这里试试这个,选择示例..:query="select...."results=ActiveRecord::Base.connection.execute(query) 关于ruby-on-rails-Rails4,使用ActiveRecord的原始查询,我们在StackOverflow上

ruby-on-rails - 如何检查 ActiveRecord 使用的数据库名称

在database.yml中定义所有设置。如何从ruby​​访问这些设置?我查看了App::Application::config,但在那里找不到它。另外,我记得人们可以在没有yaml的情况下配置数据库设置,有人知道怎么做吗? 最佳答案 Rails.configuration.database_configuration这将为您提供一个哈希表,其中包含每个环境的配置。例如。获取您的开发数据库名称:Rails.configuration.database_configuration["development"]["database"]