草庐IT

gitlab提交记录迁移

全部标签

ruby-on-rails - 在 postgresql 应用程序的 rails 中运行迁移后的序列通知

当我在postgresql上的Rails应用程序中运行我的迁移时,我得到了以下通知NOTICE:CREATETABLEwillcreateimplicitsequence"notification_settings_id_seq"forserialcolumn"notification_settings.id"NOTICE:CREATETABLE/PRIMARYKEYwillcreateimplicitindex"notification_settings_pkey"fortable"notification_settings"我的迁移文件包含088_create_notificati

ruby-on-rails - 如何使用默认的 Rails 记录器记录 Ruby 异常的整个回溯?

我正在从事rails项目,我正在尝试将异常记录到rails日志文件中。我知道我可以调用logger.error$!将异常的第一行记录到文件中。但是,我也想记录整个跟踪堆栈。如何使用默认的Rails记录器记录异常的整个回溯? 最佳答案 logger.error$!.backtrace还有,别忘了你可以rescueErrorType=>error_name为您的错误指定一个不同于默认$!的变量名。 关于ruby-on-rails-如何使用默认的Rails记录器记录Ruby异常的整个回溯?,我

ruby-on-rails - Rails 4 迁移 : how to reorder columns

我了解到add_column有一个:after选项来设置插入列的位置。太糟糕了,我才知道它:在添加了一堆之后。如何编写迁移以简单地对列进行重新排序? 最佳答案 当使用MySQL时,您可以调用change_column,但是您必须重复列类型(只需从您的其他迁移中复制并粘贴它):defupchange_column:your_table,:some_column,:integer,after::other_columnend或者如果您必须对一个表中的多个列重新排序:defupchange_table:your_tabledo|t|t.c

ruby-on-rails - 在 rails 3 中设置记录器

我正在尝试弄清楚如何将记录器与Rails3一起使用。我需要记录到控制台中没有的文件,但我只是不知道如何设置它,然后如何设置向该日志写入内容。我尝试了Rails文档,但他们并没有真正说清楚。 最佳答案 默认情况下,Rails应该将日志记录到项目的log目录中的特定于环境的日志文件中。它将被称为test.log、development.log或production.log,具体取决于您在哪个环境中运行。您可以使用Rails.logger对象直接记录到Rails的记录器:Rails.logger.info"Myinfomessage"Ra

ruby-on-rails - 如何使用 capistrano deploy 定位特定的提交 SHA

我想知道如何使用Capistrano在Git中针对特定的提交SHA进行部署?应该是这样的capdeploy--version=经过大量搜索似乎无法找到这个问题的答案。 最佳答案 对于Capistrano2.9到3.0:cap-Srevision=80655da8d80aaaf92ce5357e7828dc09adb00993deploy对于旧版本的Capistrano,您可以通过执行以下操作来部署特定的gitcommit/tree/branch/tag:cap-sbranch=80655da8d80aaaf92ce5357e7828

ruby-on-rails - 在 Rails 4.1 中,如何通过枚举符号查找记录?

假设我有这个模型:classConversation如何在不使用枚举的数值或不必遍历每个对话的情况下找到所有事件对话?我尝试执行Conversation.where(status::active),但没有产生任何结果。想到的唯一解决方案是遍历所有对话并选择事件对话,但这看起来不是一个好的解决方案。Conversation.all.select{|conversation|conversation.active?}我能做些什么吗? 最佳答案 ActiveRecord::Enum提供基于其值的范围。试试看:Conversation.ac

ruby - 如何使用 yardoc 列出未记录的模块/类/常量/方法?

我有一个小型代码库,我正在用YARD记录这些代码.当我运行yardoc命令时,它告诉我:Files:40Modules:14(0undocumented)Classes:39(0undocumented)Constants:21(4undocumented)Methods:239(31undocumented)88.82%documented与其费力地遍历我的所有代码来查找未记录的常量和方法,我希望它简单地列出未记录的项目。有人知道怎么做吗? 最佳答案 您可以使用--list-undoc选项专门列出所有未记录的对象(及其文件位置)。

ruby - 添加和删​​除引用的 Rails 迁移

使用railsgeneratemigrationAddClientToUser创建迁移文件后,我可以像这样编辑迁移文件:classAddClientToUser这是反转迁移中添加的引用列的正确方法吗? 最佳答案 导轨4.2.1railsgmigrationRemoveClientFromUsersclient:references将生成类似的迁移:classRemoveClientFromUser此外,您可以通过添加以下方式自由添加另一个或其他引用:add_reference:users,:model_name,index:true

ruby-on-rails - 如何检查 Rails 迁移中的数据库类型?

我有以下迁移,我希望能够检查当前与环境相关的数据库是否为mysql数据库。如果是mysql,那么我想执行特定于数据库的SQL。我该怎么做?classAddUsersFb 最佳答案 更短的通话时间ActiveRecord::Base.connection.adapter_name=='MySQL' 关于ruby-on-rails-如何检查Rails迁移中的数据库类型?,我们在StackOverflow上找到一个类似的问题: https://stackoverfl

ruby-on-rails - 在长期运行的项目中重新设置 Rails 迁移的基线

我的意思是字典中的“rebase”,而不是git定义...我有一个大型的、长期运行的Rails项目,其中有大约250个迁移,管理所有这些变得有点笨拙。也就是说,我确实需要一个基础来在运行测试时从中清除和重建我的数据库。所以这些里面包含的数据很重要。有没有人有任何策略可以说,在设定点转储架构-归档所有旧迁移并重新开始新迁移。显然我可以使用rakeschema:dump-但实际上我需要一种方法让db:migrate首先加载模式,然后开始运行其余的迁移。我想继续使用迁移,因为它们在开发中非常有用,但是,我无法回过头来编辑2007年的迁移,所以保留它似乎很愚蠢。 最