草庐IT

sql脚本执行

全部标签

ruby - Rake vs. Thor 的自动化脚本?

我想自动执行以下操作:使用预先选择的数据库创建一个新的RubyonRails应用程序,Git初始化它,创建一个Heroku项目,提交所有文件等。通过SSH将文件夹中的所有文件上传到另一台计算机,但不要覆盖文件。升级Ubuntu,通过apt-get安装所有基础包。据我所知,这方面的工具是Rake和Thor,但是,我应该使用哪一个?在我看来,Rake实际上更受欢迎。我听说有人推荐托尔。这些在概要中如何相互对应? 最佳答案 Rake和Thor有不同的用途。Rake是一个针对特定项目的通用构建脚本工具。换句话说,您将rakefile放入您的

ruby - 解析 Ruby 脚本中的命令行参数

我想从命令行调用Ruby脚本,并传入键/值对参数。命令行调用:$rubymy_script.rb--first_name=donald--last_name=knuth我的脚本.rb:putsargs.first_name+args.last_name执行此操作的标准Ruby方法是什么?在其他语言中,我通常必须使用选项解析器。在Ruby中,我看到我们有ARGF.read,但这似乎无法像本例中的键/值对那样工作。OptionParser看起来很有希望,但我不知道它是否真的支持这种情况。 最佳答案 Ruby的内置OptionParser

ruby - 让 sidekiq 立即执行作业

目前,我有一个像这样的sidekiq工作:classSyncUserincludeSidekiq::Workerdefperform(user_id)#dostuffendend我正在像这样在队列中放置一个作业:SyncUser.perform_asyncuser.id当然这一切都有效,但在调用perform_async和作业实际执行之间有一点延迟。我还能做些什么来告诉sidekiq立即执行作业吗? 最佳答案 这里有两个问题。如果你想立即执行一个作业,在当前上下文中你可以使用:SyncUser.new.perform(user.id

ruby - 我应该在我的 ruby​​ 脚本中定义一个 main 方法吗?

在python中,模块没有有一个main函数,但通常的做法是使用以下习惯用法:defmy_main_function():...#somecodeif__name__=="__main__":#program'sentrypointmy_main_function()我知道Ruby也没有main方法,但是有什么我应该遵循的最佳实践吗?我应该将我的方法命名为main还是什么?Wikipediapageaboutmainmethods对我没有真正的帮助。作为旁注,我还在python中看到了以下习语:defmy_main_function(args=[]):...#somecodeif__n

ruby-on-rails - 从迁移中执行 Rake 任务?

我有一个Rake任务将配置数据从文件加载到数据库中,是否有正确的ruby​​/rails方法在迁移时调用它?我的目标是同步我的团队数据库配置,无需广播然后运行任务lalaladefself.upchange_table:fis_situacao_fiscaldo|t|t.remove:mostrar_enderecot.rename:serie,:modeloendFaturamento::Cfop.destroy_all()#performrakehere!end更新我现在的工作方式和工作方式:system('rakesistema:load_datafile=faturamento

ruby-on-rails - Ruby/Rails 有没有办法执行字符串中的代码?

所以我有一个包含不同代码示例(阅读片段)的数据库。代码示例由用户创建。在Rails中有没有办法执行它?例如,我的数据库中有以下代码(id=123):return@var.reverse有没有办法让我执行它?像这样的东西:@var='Hello'@result=exec(CodeSample.find(123))所以结果会是'olleH' 最佳答案 您可以使用eval:code='@var.reverse'@var='Hello'@result=eval(code)#=>"olleH"但是这样做要非常小心;您授予该代码对您系统的完全访

ruby - 如何在 bundler 上下文中运行 ruby​​ 脚本?

我有一个名为foo.rb的Ruby脚本,我想在bundler环境的上下文中运行它。怎么办?bundleexecfoo.rb不起作用,因为exec需要一个shell脚本。 最佳答案 将脚本名称传递给ruby命令:bundleexecrubyscript_name如果你也想要Rails环境:bundleexecrailsrunnerscript_name 关于ruby-如何在bundler上下文中运行ruby​​脚本?,我们在StackOverflow上找到一个类似的问题:

ruby - 如何在 Ruby 脚本中运行 Rake 任务?

我有一个Rakefile,其中包含我通常从命令行调用的Rake任务:rakeblog:postTitle我想编写一个多次调用Rake任务的Ruby脚本,但我看到的唯一解决方案是使用``(反引号)或system进行处理。正确的做法是什么? 最佳答案 来自timocracy.com:require'rake'defcapture_stdouts=StringIO.newoldstdout=$stdout$stdout=syields.stringensure$stdout=oldstdoutendRake.application.rak

ruby-on-rails - 如何使用 postgresql 在 Rails 中执行不区分大小写的顺序

我正在将我的开发环境从sqlite3切换到postgresql8.4,还有最后一个障碍。在我原来的帮助方法中有以下行;result=Users.find(:all,:order=>"namecollateNOCASE")它提供了一个非常好的不区分大小写的搜索。我不能为postgresql复制这个。应该很简单-有什么想法吗?谢谢。 最佳答案 result=Users.find(:all,:order=>"LOWER(name)")向Brad和Frank学习一点。 关于ruby-on-rai

ruby-on-rails - bundler :在使用 gem 进行 bundle 安装期间,找不到带有可执行 bundle (Gem::GemNotFoundException) 的 gem bundler (>= 0.a)

我正在执行以下脚本:geminstallrdoc--no-documentgeminstallbundlebundle输出:+geminstallrdoc--no-documentSuccessfullyinstalledrdoc-6.1.11geminstalled+geminstallbundleSuccessfullyinstalledbundle-0.0.1Parsingdocumentationforbundle-0.0.1Doneinstallingdocumentationforbundleafter2seconds1geminstalled1geminstalled+b