草庐IT

SQL优化处理

全部标签

ruby - 如何使用 open-uri 处理 503 错误?

如果网站返回“503服务不可用”错误,则open-uri会抛出异常。例如:require'open-uri'open('http://www.google.co.uk/sorry/?continue=http://www.google.co.uk/search%3Fq%3Dhello%26oq%3Dhello%26ie%3DUTF-8')#OpenURI::HTTPError:503ServiceUnavailable#...但是,如果您随后在网络浏览器中访问它,它实际上会显示一个带有验证码的页面,而不是错误。我如何确保open-uri不只是将此作为异常抛出,而是实际处理响应并为我提供

sql - GROUP BY 和 COUNT 使用 ActiveRecord

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

ruby-on-rails - 获取 fields_for 和 accepts_nested_attributes_for 以处理 belongs_to 关系

我似乎无法使用Rails2.3的新accepts_nested_attributes_for工具在RailsView中为belongs_to关系生成嵌套表单。我确实检查了许多可用的资源,看起来我的代码应该可以工作,但是fields_for对我来说是爆炸性的,我怀疑它与如何做有关我配置了嵌套模型。我遇到的错误是一个常见的错误,可能有多种原因:'@account[owner]'isnotallowedasaninstancevariablename下面是涉及的两个模型:classAccount'User',:foreign_key=>'owner_id'accepts_nested_att

sql - Redmine:多次复制问题

复制一个问题及其子问题是一项native内置功能,因此工作正常。但是有没有办法多次这样做呢?就像将一个问题(包括它的子问题)重新创建20次或50次?编辑2这个新功能应该可以通过Redmine界面访问并与任何浏览器兼容。无论是全新的插件、内置复制功能的扩展、对PHP脚本的调用还是其他任何东西,都无关紧要。由于兼容性(网络、浏览器等),我想完全在服务器端进行修改是唯一的方法。默认插件(在投票tutorial中创建)或核心元素的哪些部分必须更改?在哪里可以找到原生问题复制功能的代码?或者-如果这一切都太复杂了-我该如何编写我的插件以指向直接操作SQL数据库的PHP文件?编辑:澄清一下:就像普

ruby - Rails 控制台未将 SQL 语句输出到我的开发日志

当我通过本地主机访问我的Webrick服务器时,或者当我运行railsmigrations时,我的development.log被正确写入。但是,当我使用“railsc”启动我的rails控制台,然后尝试创建一个新的数据库对象并通过“user.save”之类的命令保存它时,我在控制台中看到了SQL语句,但没有写入任何内容开发日志。大多数人在回答与此类似的问题时会说“检查以确保配置设置为正确的环境”。我已经这样做了,并且可以在我的系统上说这发生在一个全新的Rails应用程序上。如有任何帮助,我们将不胜感激。谢谢! 最佳答案 rails

sql - 如何使用自定义加入 rails 来加载对象?

背景正常的rails预加载集合是这样工作的:Person.find(:all,:include=>:companies)这会生成一些执行的sqlLEFTOUTERJOINcompaniesONpeople.company_id=companies.id问题但是,我需要一个自定义连接(如果我使用find_by_sql也会出现这种情况)所以我不能使用vanilla:include=>:companies自定义join/sql将为我提供我需要的所有数据,但我如何告诉activerecord它属于关联的Company对象而不仅仅是一堆额外的行?更新我需要在联接中添加其他条件。像这样:SELEC

sql - 通过关联的 Rails 查询仅限于最近的记录?

classUserhas_many:books我需要一个返回的查询:最近一本书具有:complete=>true的用户。即,如果用户最近的书有:complete=>false,我不希望它们出现在我的结果中。到目前为止我有什么User.joins(:books).merge(Book.where(:complete=>true))这是一个很有希望的开始,但没有给我需要的结果。我试过添加.order("created_ondesc").limit(1)到上述查询的末尾,但是当我期待很多结果时,我最终只得到一个结果。谢谢! 最佳答案 如果

ruby-on-rails - 如何使用 Rails 4 同时处理请求?

我正在尝试在Rails4中同时处理多个请求,我在Rails3中使用config.threadsafe!和Puma可以很轻松地做到这一点。假设我有这个ControllerclassConcurrentController我过去可以使用puma-t2:16-p3000(对于最少2个线程)启动puma,然后点击index然后show并且仍然可以正确呈现show。在Rails4中,如果我尝试做同样的事情,Puma现在会锁定index请求并且show永远不会被渲染。当我为服务器按下Ctrl-C时,Puma给我这个错误:Rackapperror:#为了让Rails4并发工作,我在这里缺少什么?co

ruby - 处理在 Ruby 线程中引发的异常

我正在寻找异常处理经典问题的解决方案。考虑以下代码:deffoo(n)puts"for#{n}"sleepnraise"after#{n}"endbeginthreads=[][5,15,20,3].eachdo|i|threadseputs"EXCEPTION:#{e.inspect}"puts"MESSAGE:#{e.message}"end此代码在5秒后捕获异常。但是如果我将数组更改为[15,5,20,3],上面的代码会在15秒后捕获异常。简而言之,它总是捕获第一个线程中引发的异常。任何想法,为什么会这样。为什么每次3秒后不捕获异常?我如何捕获任何线程引发的第一个异常?

ruby-on-rails - 处理命名空间中的命名空间模型(类)

我正在使用RubyonRails3,我想在命名空间中处理模型(类)命名空间。也就是说,如果我有一个名为NS1的命名空间和一个名为NS2的命名空间的“子命名空间”,我想在中处理模型(类)NS2。如果我运行一个脚手架railsgeneratescaffoldns1/ns2/Articleid:integertitle:string它将生成以下模型文件:models/ns1/ns2/article.rbfilemodels/ns1/articles.rbmodels/ns1/articles.rb包含:moduleNs1::Articlesdefself.table_name_prefix'