14

有一个令人沮丧的问题,我的 rails 迁移使用空格和表列的位置更新架构。

所以大多数时候当我运行bundle exec rake db:migrate它时,它会执行以下场景之一。当我将它合并到我们的主分支中并且其他开发人员解决这个问题时,他们的 Rails 迁移会恢复选项卡和位置顺序。

我们注意到,如果我是模式的最后一个提交者,则团队中的所有三个开发人员在运行迁移时都会遇到相同的问题。

我刚刚更新postgres to v9.2.4了这与其他开发人员相同。关于我还能尝试什么的任何想法?

例子

下面是 git diff 来演示正在发生的事情。

重新排序架构的示例:

   create_table "accounts", :force => true do |t|
     t.integer  "organisation_id"
-    t.boolean  "active",             :default => false
     t.text     "notes"
+    t.boolean  "active",             :default => false
   end

将选项卡添加到架构的示例:

   create_table "comments", :force => true do |t|
-    t.integer  "commentable_id",   :default => 0
-    t.string   "commentable_type", :default => ""
+    t.integer  "commentable_id",     :default => 0
+    t.string   "commentable_type",   :default => ""
-    t.datetime "created_at",                       :null => false
-    t.datetime "updated_at",                       :null => false
+    t.datetime "created_at",                            :null => false
+    t.datetime "updated_at",                            :null => false
4

4 回答 4

5

我构建了一个 gem 来解决这个问题。

它对列、索引名称和外键进行排序,删除多余的空格并运行 Rubocop 进行一些格式化以统一 schema.rb 文件的输出。

https://github.com/jakeonrails/fix-db-schema-conflicts

将其添加到 Gemfile 后,您只需像往常一样运行 rake db:migrate 或 rake db:schema:dump。

于 2014-12-02T01:15:46.333 回答
2

好消息!Rails 终于推出了一个更新来解决这个问题。从 Rails v5.1.0 开始,默认(也是唯一的选项)是删除列之间的任何多余空格。

于 2019-02-07T04:57:11.937 回答
-1

我怀疑此错误是由空格的不同配置引起的(如果您使用的是 sublime,则为“制表符宽度”)。

于 2014-04-12T15:26:48.557 回答
-15

您应该从版本控制中忽略 schema.rb。它会根据迁移的顺序和生成者的不同而有所不同。您只需要迁移来为项目中涉及的每个开发人员生成适当的架构。

问候。

于 2013-11-01T22:24:17.857 回答