草庐IT

Mysql 慢查询 - 即使有所有索引

全部标签

ruby - 使用 ActiveRecord 在查询对象中转义参数?

给定一个查询对象(不是AR模型)classComplexQueryQUERY=如何方便地转义所有参数?我成功地使用了三种技术,但没有一种是方便的。使用raw_connection(对我而言)返回PG::Conn的实例并调用exec_params。我对此并不满意,因为exec_params需要一组详细的参数来指定数据类型。在我的查询对象中包含ActiveRecord::Sanitization并使用其中一种方便的方法,例如replace_named_bind_variables。我对此不满意,因为replace_named_bind_variables是protected并且我必须使用s

ruby-on-rails - 在 Rails 中如何使用带索引的 find_each 方法?

我可以像这样使用Railsfind_each方法:User.find_each(:batch_size=>10000)do|user|------end使用find_each方法有没有办法获取数组的索引?喜欢:User.find_each(:batch_size=>10000).with_indexdo|user,index|------end 最佳答案 作为对这个问题的更新。ActiveRecord4.1.4添加了对find_each.with_index的支持,如documentation中所指出的.User.find_each

sql - 何时使用 ORM(Sequel、Datamapper、AR 等)与纯 SQL 进行查询

我的一位同事目前正在设计如下所示的SQL查询以生成报告,这些报告通过外部数据查询显示在excel文件中。目前只需要DB上的上报流程(无CRUD操作)。我试图说服他最好使用ruby​​ORM以便能够在rails/sinatra应用程序中显示数据。尽管在显示数据方面有明显的优势,但学习使用像Sequel或Datamapper这样的ORM对他有什么优势?他正在编写的SQL查询显然相当复杂,并且对SQL比较陌生,他经常提示它非常耗时且令人困惑。是否可以使用ORM编写极其复​​杂的查询?如果是这样,哪个最合适(我听说Sequel对遗留数据库有好处)?在进行复杂的数据库查询时,学习Ruby和使用O

ruby - 返回 ruby​​ 中字符串中所有出现的字符的索引

我正在尝试使用Ruby将索引返回到字符串中所有出现的特定字符。示例字符串是"a#asg#sdfg#d##"并且在搜索时预期返回是[1,5,10,12,13]#个字符。以下代码可以完成这项工作,但必须有更简单的方法吗?defoccurances(line)index=0all_index=[]line.each_bytedo|x|ifx=='#'[0]thenall_index 最佳答案 s="a#asg#sdfg#d##"a=(0...s.length).find_all{|i|s[i,1]=='#'}

ruby - each_with_index_do 索引从 1 开始

我在Rails应用程序的View上使用ruby​​迭代器,如下所示:...我想加上1..而不仅仅是说:@document.data会得到让上面的索引从1开始的技巧。但是,遗憾的是,上面的代码索引仍然是0到data.length(实际上是-1)。那么我做错了什么,我需要索引等于1-data.length...不知道如何设置迭代器来执行此操作。 最佳答案 除非你使用像1.8这样的旧Ruby(我认为这是在1.9中添加的,但我不确定),你可以使用each.with_index(1)来获得1-基于枚举器:在你的情况下它会是这样的:...

ruby-on-rails - 在 rails 中过滤 ActiveRecord 查询

我习惯了Django,在那里你可以在查询集上运行多个过滤方法,即Item.all.filter(foo="bar").filter(something="else")。然而,这在Rails中并不容易。Item.find(:all,:conditions=>["foo=:foo",{:foo=bar}])返回一个数组,这意味着这将不起作用:Item.find(:all,:conditions=>["foo=:foo",{:foo='bar'}]).find(:all,:conditions=>["something=:something",{:something='else'}])所以我

ruby-on-rails - 如何在 Rails 控制台中查看 MySQL 查询

这个问题在这里已经有了答案:HowtoshowSQLqueriesrunintheRailsconsole?(8个答案)关闭8年前。有没有办法在Rails控制台中查看从ActiveRecord触发了哪些MySQL查询?

Ruby Mine 提示 "Cannot switch SDK."即使 SDK 存在并且可用

MyRubyMine6.0.3给出消息:Project.ruby-versionSettings:CannotswitchSDK.RVMSDK'2.1.1@rails3'wasn'tfound.我使用rvm管理ruby​​环境。想要的环境似乎还可以:rvmgemsetlistgemsetsforruby-2.1.1(foundin/home/agostino/.rvm/gems/ruby-2.1.1)(default)globalrails3=>testproject不仅如此,自从打开文件后,我的设置似乎也能很好地访问rvm环境,我可以看到设置:那么为什么不能切换到正确的环境呢?如果在

ruby-on-rails - 如何在 OS X 上使用 ruby​​ 2.3 为 mysql2 gem 解析 "incompatible library version"?

我使用的是ruby​​2.3,在gemfile中,我列出了mysql2gem。但是当我尝试运行rakedb:migrate时,我得到以下信息:/Users/me/.gem/ruby/2.3.0/gems/mysql2-0.4.2/lib/mysql2.rb:31:in`require':incompatiblelibraryversion-/Users/me/.gem/ruby/2.3.0/gems/mysql2-0.4.2/lib/mysql2/mysql2.bundle(fatal)我似乎无法绕过这个。我用Homebrew安装了Mysql5.7,尝试更新包,卸载并重新安装mysql

ruby - 为什么即使未执行该代码路径,Ruby 似乎也会从 case 语句内部提升变量声明?

这个问题在这里已经有了答案:WhycanIrefertoavariableoutsideofanif/unless/casestatementthatneverran?(3个答案)关闭5年前。我们定义一个函数foo:deffoo(s)caseswhen'foo'x=3putsx.inspectwhen'bar'y=4putsy.inspectendputsx.inspectputsy.inspectend然后我们这样调用它:1.9.3p194:017>foo('foo')infooscope3inouterscope3nil=>nil1.9.3p194:018>foo('bar')in