草庐IT

SQL查询根父子记录

全部标签

ruby - 如何在像 nginx 这样的代理后面时在 rails 日志中记录真实的客户端 ip

问题我在两台服务器上安装了Rails3.2.15和机架1.4.5。第一个服务器是服务于静态Assets的nginx代理。第二台服务器是为Rails应用程序提供服务的unicorn。在Railsproduction.log中,我总是看到nginxIP地址(10.0.10.150)而不是我的客户端IP地址(10.0.10.62):StartedGET"/"for10.0.10.150at2013-11-2113:51:05+0000我想在日志中有真实的客户端IP。我们的设置HTTPheaderX-Forwarded-For和X-Real-IP在nginx中设置正确,我已经定义了10.0.1

ruby-on-rails - 在没有额外的 sql 查询的情况下过滤 activerecord 关系?

如何在不执行额外查询的情况下过滤AR查询的结果?例如u=User.where(name:"bob",age:[10,20])#1stselectquerytodbu.class#ActiveRecord::Relationtens=u.where(age:10)#2ndselectquerytodb我不希望第二个查询调用数据库,而是过滤在u(第一个查询)中检索到的结果。 最佳答案 ActiveRecord:Relation仅在访问其元素时查询数据库。因此,您拥有的序列根本不会调用数据库,除非您编写类似u.first或tens.fir

ruby - 从 ActiveRecord 原始 SQL 获取类型化结果

在Sequel中,我可以做到:irb(main):003:0>DB["selectfalse"].get=>false返回一个错误的bool值。我希望能够在ActiveRecord中做类似的事情:irb(main):007:0>ActiveRecord::Base.connection.select_value"selectfalse"=>"f"如您所见,它返回字符串"f"。有没有办法用ActiveRecord得到一个错误的bool值?(类似地,我可能正在调用一个返回timestamptz、数组等的函数——我希望返回的值具有正确的类型)我的用例:我正在调用一个数据库函数,想要返回一个键

ruby-on-rails - 如何要求在 Rails 之外工作的事件记录

我需要要求事件记录,但我在rails之外工作(原因如下:SimpleRubyInputValidationLibrary)。我需要require整个railsgem,还是我可以成为DRYer? 最佳答案 下面是我在Rails之外使用ActiveRecord的方式:#!/usr/bin/rubyrequire'active_record'require'mysql2'#or'pg'or'sqlite3'ActiveRecord::Base.establish_connection(adapter:'mysql2',#or'postgr

sql - GROUP BY 和 COUNT 使用 ActiveRecord

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

ruby - 如何使用 Active Record 查找具有重复数据的记录

使用ruby​​和新的Activerecord查找列中具有重复值的记录的最佳方法是什么? 最佳答案 将@TuteC翻译成ActiveRecord:sql='SELECTid,COUNT(id)asquantityFROMtypesGROUPBYnameHAVINGquantity>1'#=>Type.select("id,count(id)asquantity").group(:name).having("quantity>1") 关于ruby-如何使用ActiveRecord查找具有重

ruby-on-rails - 如何从ActiveRecord 中获取每个组的最新记录?

在我的RubyonRails应用程序中,我有一个这样的数据库结构:Project.create(:group=>"1",:date=>"2014-01-01")Project.create(:group=>"1",:date=>"2014-01-02")Project.create(:group=>"1",:date=>"2014-01-03")Project.create(:group=>"2",:date=>"2014-01-01")Project.create(:group=>"2",:date=>"2014-01-02")Project.create(:group=>"2",:

ruby-on-rails - Rails - 使用 axlsx gem (Keep MVC) 将记录导出到可下载的 excel 文件

我已经从https://github.com/randym/axlsx成功安装了axlsxgem这是我用来通过这个gem创建excel文件的Controller代码。但是这段代码没有任何反应,而是显示了一个错误未初始化的mimeclassCoaches::PaymentsControllerparams[:page],:order=>sort_column+""+sort_direction)else@payments=Payment.includes(:member).paginate(:page=>params[:page],:order=>'iddesc')endrespond_

ruby - 如何优雅地检查 RSpec 中记录的存在

有没有更好的方法来检查RSpec中是否存在记录?Foo.where(bar:1,baz:2).count.should==1 最佳答案 与Rspec2.13.0,我能够做到Foo.where(bar:1,baz:2).shouldexist编辑:Rspec现在有anexpectsyntax:expect(Foo.where(bar:1,bax:2)).toexist 关于ruby-如何优雅地检查RSpec中记录的存在,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - 将参数值传递给 redirect_to 作为 rails 中的查询字符串

这应该很简单,但我似乎找不到简单的答案。如何将当前请求的参数值传递到redirect_to调用中?我有一些表单值想传递到GET重定向的查询字符串中我想做这样的事情:redirect_to@thing,:foo=>params[:foo]并发送到:http://things/4?[foo][key1]=val1&[foo][key2]=val2谢谢!此外-对于redirect_to:back如何处理?redirect_to:back,:foo=>params[:foo] 最佳答案 redirect_to的“记录”形式仅将第二个参数用于