草庐IT

DB_Variable

全部标签

ruby-on-rails - rake db :migrate doesn't work after ruby 2. 2.2 到 2.2.3 通过 RVM 升级

我最近使用RVM从Ruby2.2.2升级到2.2.3。这搞砸了我的开发环境中的一些事情,但由于有用的错误消息,到目前为止我可以处理它。现在我想向我的数据库添加一些迁移,但遇到了这个错误:$rakedb:migrate/Users/howard/.rvm/gems/ruby-2.2.3/bin/ruby_executable_hooks:15:in`eval':/Users/howard/.rvm/rubies/ruby-2.2.3/bin/rake:4:syntaxerror,unexpectedtSTRING_BEG,expectingkeyword_door'{'or'('(Syn

ruby-on-rails - 处理 undefined variable

我在一个View中渲染局部:@video,:video_id=>'video_show_id'%>并在部分中包含此代码:"oembed",:id=>video_id%>"oembed"%>问题是这个部分在我的应用程序中的许多地方呈现,并且在那些其他View中我不想将:video_id传递到部分。因此,我的应用会抛出一个错误,指出video_id未定义。我可以将:video_id=>""传递到其他View中的部分,但由于部分在许多地方呈现,这有点痛苦。有没有更简单的方法来处理这个问题? 最佳答案 尝试defined?并不是说​​它真的

ruby - 带有删除表的 rake db :migrate updating schema. rb

我在git上有几个分支,跨这些分支的模式在不同的版本上。切换到分支后,让我们说new_feature(有挂起的迁移)如果我做rakedb:setup然后它建议我运行挂起的迁移。一旦我这样做,我的架构就会更新为在同一分支中删除的表。如果我执行rakedb:reset然后它工作正常。我知道db:setup和db:reset之间的区别。后者执行db:drop然后执行db:setup但我想知道为什么架构会在rakedb:migrate上显示那些删除的表我肯定缺少一些Rails知识w.r.t.模式加载和迁移过程任何见解都会有很大帮助。提前致谢 最佳答案

ruby - RSpec 2之前(:suite) variable scope

基本上我想创建一个数组,然后在我的规范中附加到它,然后再最终处理并将它显示给用户。我可以想出一些解决方法,但理想情况下我想执行以下操作。RSpec.configuredo|config|config.before(:suite){@array_of_stuff||=[]}config.after(:suite){process_and_print(@array_of_stuff)}enddefprocess_and_print(array)#dostuffend不幸但并不令人惊讶的是@array_of_stuff不在范围内并且不能从我的规范中追加,这与在before(:all)bloc

ruby - 使用 :sql 模式格式时如何使 rake db :migrate generate schema. rb

如果在config/application.rb中使用这个选项:config.active_record.schema_format=:sql然后当你这样做时:rakedb:migrate它只转储db/structure.sql。我知道它没有使用db/schema.rb因为它使用的是:sql选项,但是你如何制作rakedb:migrate还生成db/schema.rb吗?我们需要它,因为RubyMine4.5和IntelliJIDea11使用db/schema.rb来自动完成列。 最佳答案 要生成/更新db/schema.rb,即使

ruby - 在 Ruby 中,对于 undefined variable "foo",为什么 "foo = foo"不引发错误?

当foo是一个undefinedvariable时,试图访问它会引发一个NameError:foo#=>NameError:undefinedlocalvariableormethod`foo'a=foo#=>NameError:undefinedlocalvariableormethod`foo'为什么foo=foo不引发NameError?foo=foo#=>nil昨天,我花了几个小时才将这一行作为程序中的错误来追踪......capture=capture.to_i我本来打算做的是将capture_str转换为Integer。我所做的是通过说capture=capture来引入n

ruby - 可配置的 ruby​​ 记录器设置 : Logger. new().level = variable

我想更改应用程序(ruby)的日志记录级别。require'logger'config={:level=>'Logger::WARN'}log=Logger.newSTDOUTlog.level=Kernel.const_getconfig[:level]好吧,irb对此并不满意,并向我抛出“NameError:错误的常量名称Logger::WARN”。啊!我被侮辱了。我可以在某些情况下/何时解决这个问题,或者做log.level=1,但必须有更优雅的方法!有没有人有什么想法?-丹尼尔 最佳答案 为什么不直接在config哈希中使用

ruby-on-rails - rake db::migrate 是如何工作的

我刚刚真正开始使用Ruby和Rails,我发现自己真正喜欢的事情之一就是它让您使用的约定。我想在我自己的非Ruby项目中模仿这种行为。我的问题是它实际上是如何工作的?我知道我可以查看Rails代码,但我的理解还不够深入,无法了解其中发生了什么。我知道它需要一个基线脚本,然后针对它运行更新架构更改。但是它怎么知道它的版本是什么?我如何在另一个框架/数据库中模仿它? 最佳答案 注意:目前Rails2.x也是如此。它可能不适用于Rails3,因为我花在Rails3上的时间没有我希望的那么多。Rails创建了一个名为schema_migra

ruby-on-rails - 将时间戳添加到 db Rails 5+ 中的现有表

正在尝试将时间戳添加到现有表中。根据Apidocumenationadd_timestamps这是我的迁移代码:defchangeadd_timestamps(:products,null:false)end获取错误:*--add_timestamps(:products,{:null=>false})railsaborted!StandardError:Anerrorhasoccurred,thisandalllatermigrationscanceled:SQLite3::SQLException:CannotaddaNOTNULLcolumnwithdefaultvalueNUL

ruby-on-rails - 为什么 `rake db:drop` 失败时退出状态为 0,并且不引发错误?

我惊讶地发现,当rakedb:drop(假设是Rails的其他内置raketasks)失败时,bash状态代码为0。$rakedb:dropcouldnotconnecttoserver:ConnectionrefusedIstheserverrunningonhost"localhost"(::1)andacceptingTCP/IPconnectionsonport5432?...$echo$?0也许更令人惊讶的是,当从Rails中调用任务时,它甚至不会引发错误。2.3.0:001>begin2.3.0:002>Rake::Task["db:drop"].invoke2.3.0:0