草庐IT

mysql - ActiveRecord 查询 : order by a sum on an included model

全部标签

ruby-on-rails - 如何使用 Ruby on Rails 创建一个新的 ActiveRecord 连接池?

我有一个RoR应用程序,它与RoR主数据库配合得很好。我还想以某种方式连接到任意数据库,这样我就不会为每个新的HTTP请求重新创建数据库连接。根据我的研究,连接池似乎是可行的方法。但是,我无法弄清楚如何自己创建池:config=ActiveRecord::ConnectionAdapters::ConnectionSpecification.new({"adapter"=>"postgresql","host"=>"localhost","port"=>9000,"database"=>"foo_test","username"=>"foo","password"=>"bar","po

ruby-on-rails - 如何正确处理 Rails 中的 ActiveRecord::RecordNotUnique

我试图在我的Rails项目中使用唯一索引来强制执行唯一性。我发现了一些令人困惑的事情。就像在我的站点注册用户一样,您需要提供电子邮件地址和昵称,两者都必须是唯一的。我为电子邮件和昵称添加了唯一索引。当重复出现时,我拯救异常ActiveRecord::RecordNotUnique,现在问题来了,我怎么知道哪个字段导致异常?非常感谢您的帮助。 最佳答案 恕我直言,您还应该添加uniquenessvalidators到你的模型。这允许您使用Rails的验证和错误消息。#addtomodelvalidates:email,uniquene

sql - ActiveRecord 的意外行为包括

我正在使用ARincludes在对象User和Building之间执行LEFTOUTERJOIN的方法,其中User可能有也可能没有Building关联:users=User.includes(:building).references(:buildings)因为我正在使用references,任何关联的Building对象都将被预先加载。我的期望是我随后能够遍历用户列表,并检查用户是否有与其关联的建筑物而不会触发额外的查询,但实际上每当我尝试访问建筑物属性时我都会看到对于没有建筑物的用户,AR会进行另一个SQL调用以尝试检索该建筑物(尽管在后续尝试中它只会返回nil)。这些查询显然是

ruby-on-rails - Fork、Ruby、ActiveRecord 和 Fork 上的文件描述符

我知道当我们fork一个进程时,子进程会继承父进程的打开文件描述符和偏移量的副本。根据手册页,这指的是父级使用的相同文件描述符。基于以下程序中的理论puts"Process#{Process.pid}"file=File.open('sample','w')forked_pid=forkdosleep(10)puts"Writingtofilenow..."file.puts("HelloWorld.#{Time.now}")endfile.puts("Welcometowinterofmydiscontent#{Time.now}")file.closefile=nil问题一:当父进

ruby-on-rails - ActiveRecord::QueryCache#call 占用了超过 70% 的执行时间

NewRelic向我展示了应用服务器中超过80%的执行时间发生在“MiddlewareActiveRecord::QueryCache#call”中这里是相关测试代码的要点(尽管我在其他API端点上看到了类似的结果)。Gist我正在AWSElasticBeanstalk上的t2.medium实例和t2.smallPostgresRDSDB上运行应用程序服务器,max_connections设置为100。我正在通过loader.io对此进行测试,对100个用户进行测试使用维护客户端负载设置(这意味着每分钟大约6000个请求)。有谁知道为什么QueryCache花费这么多时间?

sql - 如何查询具有 3 个标签的事件?

我有以下模型:activity.rbtag.rbtagging.rb标签是事件和标签的连接模型。我想搜索具有2个或更多标签的事件。我如何在Rails中执行此操作?例如:我有tag1=Christmas,tag2=Florida,tag3=John如果存在,我想找到tag1、tag2和tag3存在的Activity。[编辑]我最终做了什么:tags=[tag1,tag2,tag3]activities=[]tags.eachdo|tag|activities如果任何组值的大小等于tags.size,则该事件包含所有标签。 最佳答案 如

ruby-on-rails - 是否可以只从 ActiveRecord 关联请求某些列?

考虑defFoohas_one:userend假设我只想要一个Foo的User的名称,而不是任何其他列。所以我要SELECTnameFROM"users"WHERE"prices"."id"=123但是做foo.user.name会给我SELECT*FROM"users"WHERE"prices"."id"=123有什么巧妙的方法可以使用关联来只获取一列吗?如果没有,那么我必须这样做:User.where(id:foo.user_id).pluck(:name).first 最佳答案 通常,您可以使用.select方法指定要选择的列

ruby - 如何让 Ruby 的 RestClient 使用多值查询参数?

使用RestClientgem,我需要创建如下请求:GEThttp://host/path?p=1&p=2完成此操作的正确语法是什么?请注意,接收主机不是Rails。尝试过:resource=RestClient::Resource.new('http://host/path')params={p:'1',p:'2'}#^Overridesparamtohavevalueof2(?p=2)params={p:['1','2']}#^resultsin'p[]=abc&p[]=cde'(array[]indicatorsnotwanted)resource.get({params:par

ruby-on-rails - 如何完全重新加载 ActiveRecord 以重置其内存值?

在RSpec测试中,我创建了一个记录,其中包含多个内存值。foo.reload对对象的属性按预期工作,但内存的属性仍然存在。到目前为止,它通过完全重新创建对象来工作:foo=Foo.find(123)但在我的例子中,查找记录的逻辑实际上更复杂。什么是完全重新加载记录并删除所有内存值的好方法? 最佳答案 好的方法是您已有的方法:完全重新创建对象。您不能以任何简单的“Rails”方式“重新加载”对象的内存值,因为内存属性不是Rails或ActiveRecord的功能。两者都不知道您是如何内存方法的。

ruby-on-rails - Rails 查询 : Filter by properties in another table

我正在寻找一个清晰的Rails4示例,说明如何根据通过另一个表关联的数据过滤记录。假设我有一个用户模型和一个评论模型。一个用户has_many评论,一个Commentbelongs_to一个用户。评论在其表中也有一个score列。classUserUsers|id|name|email||-----|---------|---------------------||1|"Alice"|"alice@example.com"||2|"Bob"|"bob@example.com"||...|classComment我如何获得所有对内容“k”发表评论且分数>0的用户?请注意,我要返回的是用户