草庐IT

sql脚本执行

全部标签

ruby-on-rails - 如何在 Rails 之外的 ruby​​ 脚本中使用 ActiveRecord?

我有一个小的ruby​​脚本,我想在其中使用ActiveRecord轻松访问数据库模型。最好的方法是什么? 最佳答案 require'active_record'#ChangethefollowingtoreflectyourdatabasesettingsActiveRecord::Base.establish_connection(adapter:'mysql2',#or'postgresql'or'sqlite3'or'oracle_enhanced'host:'localhost',database:'your_databa

sql - ActiveRecord Arel OR 条件

如何使用逻辑OR而不是AND来组合2个不同的条件?注意:2个条件是作为rails范围生成的,不能轻易地直接更改为where("xory")之类的内容。简单的例子:admins=User.where(:kind=>:admin)authors=User.where(:kind=>:author)很容易应用AND条件(对于这种特殊情况是没有意义的):(admins.mergeauthors).to_sql#=>select...from...wherekind='admin'ANDkind='author'但是您如何生成具有2个不同Arel关系的以下查询?#=>select...from.

ruby - 如何在 IRB 中重新加载脚本?

我正在编写一个用于Rails环境的Ruby脚本,但我选择从irb运行它,因为重新加载Rails控制台会很麻烦。现在irb的等待时间要短得多,但我很烦恼每次进行更改时都必须重新启动irb并需要脚本。有没有更简单的方法从irb重新加载脚本?我在thisthread中找到了一个方法,但这显然只适用于gem文件。我的require语句看起来像这样require"#{File.expand_path(__FILE__)}/../lib/query"编辑:尝试过load而不是require后,我仍然无法让它工作。我无法阻止这些错误。ruby-1.9.2-p0>load"#{File.expand_

ruby - 从 Rakefile 执行 bash 命令

我想从Rakefile中执行一些bash命令。我在我的Rakefile中尝试了以下内容task:hellodo%{echo"World!"}end但是在执行rakehello时没有输出?如何从Rakefile执行bash命令?注意:这不是重复的,因为它专门询问如何从Rakefile执行bash命令。 最佳答案 我认为rake希望这种情况发生的方式是:http://rubydoc.info/gems/rake/FileUtils#sh-instance_method示例:task:testdosh"ls"end内置的rake函数sh负

ruby - 如何在ruby脚本中隐藏从终端输入的密码

我是ruby新手。我需要通过gets命令接收密码作为输入。如何在gets调用期间隐藏终端输入的密码 最佳答案 也可以使用coreruby​​。$riIO.noecho(fromrubycore)------------------------------------------------------------------------------io.noecho{|io|}------------------------------------------------------------------------------Y

ruby-on-rails - 如何在 RSpec 测试中打开 ActiveRecord 的 SQL 调试日志记录?

我对我的模型进行了一些RSpec测试,我想像在Rails服务器模式中看到的那样打开SQLActiveRecord日志记录。如何做到这一点?我开始我的测试RAILS_ENV=testbundleexecrspecmy/test_spec.rb谢谢 最佳答案 您可以尝试在某处的测试中将ActiveRecord记录器设置为标准输出。如果您正在使用rspec,也许在spechelper中?ActiveRecord::Base.logger=Logger.new(STDOUT) 关于ruby-on

ruby-on-rails - 由于 readline 错误,无法执行 "rails console"

由于这个错误,我无法执行railsconsole:localhost:TwitterForZombieswiz$railsc/Users/wiz/.rbenv/versions/1.9.3-p194/lib/ruby/1.9.1/irb/completion.rb:9:in`require':dlopen(/Users/wiz/.rbenv/versions/1.9.3-p194/lib/ruby/1.9.1/x86_64-darwin12.2.1/readline.bundle,9):Librarynotloaded:/usr/local/opt/readline/lib/libre

ruby - 在 Ruby 脚本中运行命令行命令

有没有办法通过Ruby运行命令行命令?我正在尝试创建一个小的Ruby程序,它可以通过命令行程序(如“screen”、“rcsz”等)拨出和接收/发送。如果我能将所有这些与Ruby(MySQL后端等)结合起来,那就太好了 最佳答案 是的。有几种方式:a.使用%x或'`':%x(echohi)#=>"hi\n"%x(echohi>&2)#=>""(prints'hi'tostderr)`echohi`#=>"hi\n"`echohi>&2`#=>""(prints'hi'tostderr)这些方法将返回标准输出,并将标准错误重定向到程序

ruby - Ruby 是否执行尾调用优化?

函数式语言导致使用递归来解决很多问题,因此它们中的许多都执行尾调用优化(TCO)。TCO导致从另一个函数(或它本身,在这种情况下,此功能也称为尾递归消除,它是TCO的子集)调用一个函数,作为该函数的最后一步,不需要新的堆栈框架,这减少了开销和内存使用。Ruby显然从函数式语言中“借用”了很多概念(lambda、map等函数等),这让我很好奇:Ruby是否执行尾调用优化? 最佳答案 不,Ruby不执行TCO。但是,它也不执行TCO。Ruby语言规范并未提及任何有关TCO的内容。它没有说您必须这样做,但也没有说您不能这样做。你不能依赖它

ruby-on-rails - 正确执行 redirect_to :back in Ruby on Rails when referrer is not available

我在使用redirect_to:back时遇到问题。是的,它是推荐人。我经常遇到异常(ActionController::RedirectBackError)"NoHTTP_REFERERwassetintherequesttothisaction,soredirect_to:backcouldnotbecalledsuccessfully.Ifthisisatest,makesuretospecifyrequest.env[\"HTTP_REFERER\"]."我意识到这是由于推荐人不可用造成的。有没有一种方法,例如,可以在访问最后一个页面的每次访问时设置一个session变量,并且