草庐IT

PHP API脚本两次插入MySQL数据库

全部标签

ruby-on-rails - 将没有默认值的 NOT NULL 字段添加到填充的数据库中

我有一个表,我们称它为MyTable。它是Postgresql数据库的一部分。MyTable中有很多条目,比方说超过一百万。我想向该表中添加一个字段,我们将其命名为MyNewField。它由ActiveRecord迁移添加。此字段没有默认值且不可为空。结果,在它的迁移类中将是这样的:classAddMyFieldToMyTable但是,它会触发一个错误(PG::NotNullViolation),因为该表已经包含行,所有这些行的MyField都设置为NULL。我想做的是:添加没有默认值且可空设置为false的行(不触发PG::NotNullViolation)。然后,将另一个表中的值插

ruby-on-rails - Ruby 独立脚本中的 RoR 环境

我想运行一个独立的ruby​​脚本,我需要在其中使用我的RoR环境。具体来说,我需要我的模型扩展ActionMailer和ActiveRecord。我还需要从我的database.yml中读取数据库配置。我该怎么做? 最佳答案 最简单的方法是将脚本的shebang更改为:#!/usr/bin/ruby到#!/path/to/your/rails/script/runnerEtvoilà,您的脚本将在加载完整rails环境的情况下运行。您还可以将脚本作为./my_script-eproduction运行,以使其与生产数据库一起运行。

ruby - 如何编写插入 rspec 示例的方法?

在一堆rspecrails单元规范中,我做了类似的事情:describeFoodo[:bar,:baz].eachdo|a|it"shouldhavemany#{a}"doFoo.shouldhave_many(a)endendend为了更简洁的代码,我宁愿这样做:describeFoodospec_has_manyFoo,:bar,:bazend那么我该如何编写像spec_has_many()这样的辅助方法来像rspec的it()方法那样插入DSL代码呢?如果它是一个普通的实例方法,我会做类似的事情:defspec_has_many(model,*args)args.eachdo|a

ruby-on-rails - 如何在 ruby​​onrails 上将数据从模型导出到 excel 文件

我正在尝试将数据从我的模型导出到Excel电子表格。我见过3种方式使用我不明白如何使用的电子表格gem,我看到的示例是写入本地文件,但我正在寻找每次用户点击链接时都会生成一个文件。创建一个名为export的方法,并在那里运行查询,然后在我看来创建一个export.xls文件,然后该文件创建我想将表格导出到excel文件,但是这种做法不允许我创建多张纸。学习了本教程,http://oldwiki.rubyonrails.org/rails/pages/HowToExportToExcel,但是这里没有显示如何将链接放在View中,在我看来我在路由中遗漏了一些东西,我可以提供github以

ruby-on-rails - 当多个应用程序在 Ruby 中共享同一个数据库时如何管理迁移?

我有一个Rails应用程序和一个Sinatra应用程序,共享同一个数据库。Sinatra应用程序使用ActiveRecord。我能否从每个应用程序中运行迁移,就好像它们在同一个应用程序中一样?这会导致任何问题吗?Rails应用程序中的schema.rb文件通过以下方式跟踪当前迁移ActiveRecord::Schema.define(:version=>20121108154656)do但是,Sinatra应用如何知道数据库的当前版本?Rails3.2.2,Ruby1.9.3。 最佳答案 schema_migrations表中的版本

ruby-on-rails - 基于数据库模型的动态 Rails 路由

所以我正在构建一个需要基于两种不同类型的路由的Rails站点我有一个语言模型和一个类别模型所以我需要能够转到语言路径/ruby以查看顶级ruby​​资源,还可以转到/books以查看所有语言的顶级书籍我试过这样的路线get'/:language',to:"top_voted#language"get'/:category',to:"top_voted#category"问题是逻辑无法弄清楚两者之间的区别,导致后端发生一些冲突这个我也试过Language.all.eachdo|language|get"#{language.name}",to:"top_voted#language",:

ruby - ruby 中的过程和数据抽象

我是Ruby新手。我正在学习ruby​​中的抽象原则。据我了解,过程抽象是对用户隐藏实现细节,或者只是专注于要点而忽略细节。我关心的是如何实现它1)是不是一个简单的函数调用就这样#functiontosortarray#@paramsarray[Array]tobesortdefmy_sort(array)returnarrayifarray.sizearray[i+1]array[i],array[i+1]=array[i+1],array[i]swapped=trueendendendarrayend然后这样调用sorted_array=my_sort([12,34,123,43,

ruby-on-rails - 如何让 VSCode 在 'end' 后自动插入 'do'

我想尝试使用visualstudiocode来编写ruby​​/rails,然后遇到了这个问题,当我在编辑器中写“do”然后按回车键时,“end”不会自动添加到下一行。写'def'+enter可以正常工作。'begin'+enter也可以正常工作,但'do'+enter不行。我还没有找到任何可以让它工作的扩展,谷歌也没有太大帮助。也许有一种方法可以自己定义狙击手?提前致谢! 最佳答案 我找到了一个目前就足够的解决方法。使用Code->Preferences->UserSnippers->Ruby我添加了以下代码片段"Doblock"

ruby-on-rails - Ruby 类评估,validates_inclusion_of 与动态数据

如果我有如下的ActiveRecord模型classFooself.allowed_typesdefself.allowed_types#somecodethatreturnsanenumerableendend这不起作用,因为在评估验证时尚未定义allowed_types方法。我能想到的所有修复基本上都是围绕将方法定义移到验证之上,以便在需要时可用。我明白这可能更像是一个编码风格问题(我希望我的所有验证都在模型顶部,方法在底部)但我觉得应该有某种解决方案,可能涉及初始模型加载的惰性评估?我想做的事有可能吗?我应该只在验证之上定义方法,还是有更好的验证解决方案来实现我想要的。

ruby - Supervisord:如何获取 rvm 和 bundle exec 来启动 rails 脚本?

我正在尝试使用supervisord管理一个ruby​​脚本,但是因为我还没有完全理解RVM是如何工作的,所以我无法正确地完成它。通常我会做以下事情:#sourcingofrvmdoneautomaticallyonsshlogincd/var/rails/myappRAILS_ENV="production"bundleexec./script/backgroundrb但是使用下面的配置文件我做不到:[program:owgm]directory=/var/rails/owgmcommand=bundleexec./script/backgroundrbenvironment=RAI