草庐IT

SQL语句优化的30种方法

全部标签

sql - 从 Rails 4 应用程序调用大量 SQL

我有一个Rails4应用程序,我将它与sidekiq结合使用来运行异步作业。我通常在Rails应用程序之外运行的作业之一是大量复杂的SQL查询,这些查询实际上无法通过ActiveRecord建模。这组SQL查询与我的Rails应用程序的联系是它应该在我的Controller操作之一被调用时执行。理想情况下,我会在Controller中将我的Rails应用程序的作业排队,以便Sidekiq继续运行查询。现在它们存储在一个外部文件中,我不完全确定让Rails运行上述SQL的最佳方法是什么。感谢任何解决方案。 最佳答案 我同意Sharag

ruby - 一种在保持绝对路径的同时解析相对路径的 Ruby 方法?

我正在编写一个跨平台(MacOSX、Linux、Windows)的rakebuildscrip。构建脚本将被CIserver使用.我希望我的脚本逻辑如下:如果确定路径是相对路径,则通过output_path=FOO_HOME+user_supplied_relative_path使其成为绝对路径如果确定路径是绝对路径,则按原样我目前正在使用Pathname.new(location).absolute?但它在Windows上无法正常工作。为此您建议采用哪种方法? 最佳答案 require'pathname'(Pathname.new

ruby - 在 ruby​​ 中继承 initialize() 方法?

这个问题不太可能帮助任何future的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visitthehelpcenter.关闭9年前。我仍然不知道如何让子类的构造函数跟随其父类...示例:require'mechanize'classScraperattr_accessor:agentdefinitialize#Idontknowifusinginstancevariableistherightthingtodo@agent=Mechanize.newendendclassScraper

ruby - 2 if语句中的条件

我正在尝试检测电子邮件地址是否不是两个域之一,但我在使用ruby​​语法时遇到了一些问题。我目前有这个:if(!email_address.end_with?("@domain1.com")or!email_address.end_with?("@domain2.com"))#DoSomethingend这是条件的正确语法吗? 最佳答案 这里不是or,而是逻辑&&(和),因为您正试图找到匹配两者的字符串。if(!email_address.end_with?("@domain1.com")&&!email_address.end_w

ruby - 如何将方法动态定义为私有(private)?

这似乎不起作用:classTestprivatedefine_method:private_methoddo"uh!"endendputsTest.new.private_method 最佳答案 Test.instance_eval{private:private_method}或者,直接运行private:private_method来自Test类。 关于ruby-如何将方法动态定义为私有(private)?,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - Rails redirect_to 发布方法?

redirect_to:controller=>'groups',:action=>'invite'但我收到错误消息,因为redirect_to发送GET方法我想将此方法更改为“POST”,在redirect_to中没有:method选项我该怎么办?我可以在没有redirect_to的情况下执行此操作吗?编辑:我在groups/invite.html.erb中有这个{:user_id=>friendship.friend.id,:group_id=>@group.id,:sender_id=>current_user.id,:status=>"requested"}),:method=

ruby-on-rails - `name' :String 的未定义方法 "SystemTimer"

我在让一年内无法运行的旧RubyonRails2应用程序运行时遇到问题。我正在尝试在我的项目目录的根目录中运行raketest:functionals,但我得到的是undefinedmethod'name'for"SystemTimer":String。我已将我认为与问题相关的所有内容粘贴到此处:http://pastebin.com/NgBvystZ此外,当我自己运行rake时,我得到运行测试时出错:units!不确定如何调试。我已经复制并粘贴了我认为对理解这个问题有用的所有内容。非常感谢您的宝贵时间。谢谢。 最佳答案 这是高于1

ruby - 在 Ruby + TinyTDS 中参数化 SQL 查询

我试图弄清楚如何在将SQL字符串交给执行之前对其进行参数化,但遗憾的是我发现了很多ofthis在互联网上:sql="SELECT*FROMtable_nameWHEREthingLIKE'%#{input}%'"这是一件坏事...但是,参数化sql查询在底层可用Sequel库,这是TinyTDS构建的基础。所以我知道这是可能的。我只是很难弄明白。我真的希望它能像this一样简单:@client=TinyTds::Client.new(:adapter=>'sqlserver',:host=>host,:database=>db,:username=>username,:password

ruby - 为什么不能使用要处理的符号调用 protected 方法?

给定以下类:classFoodefadup.tap{|foo|foo.bar}enddefbdup.tap(&:bar)endprotecteddefbarputs'bar'endend看起来Foo#a和Foo#b应该是等价的,但它们不是:>Foo.new.abar=>#>Foo.new.bNoMethodError:protectedmethod`bar'calledfor#这是有原因的吗?这是错误吗?在Ruby2.2.3p173上测试 最佳答案 让我们首先注意,在Ruby中,您可能知道,在类Foo上声明的方法a中,我可以在任何对

ruby open-uri打开方法丢失文件扩展名打开图片

我正在使用ruby​​1.9.2以及Rails3.1.4和Paperclip2.4.5。我的问题是尝试从URI保存回形针附件会丢失文件扩展名并保存文件而不会导致诸如需要扩展名的fancybox之类的问题。一些示例代码:uri="http://featherfiles.aviary.com/2012-06-13/bbe5f0de1/0c5a672b88ea47ecb4631ac173e27430.png"open(uri)#=>#因为临时文件上没有扩展名回形针正在保存文件而没有导致问题。有人遇到过这个问题吗?我已经看到关于使用回形针存储来自URI的图像的多个答案,但似乎没有一个解决我们正