Migracja Rails 4: Jak zmienić kolejność kolumn

Dowiedziałem się, że add_column mA opcję :after, aby ustawić miejsce wstawiania kolumny. Szkoda, że się o tym dowiedziałem :po dodaniu kilku

Jak mogę napisać migrację, aby po prostu zmienić kolejność kolumn?

Author: emersonthis, 2013-09-19

2 answers

Możesz wywołać change_column, ale musisz powtórzyć typ kolumny (wystarczy skopiować i wkleić go z innej migracji):

def up
  change_column :your_table, :some_column, :integer, after: :other_column
end

Lub jeśli musisz zmienić kolejność wielu kolumn w jednej tabeli:

def up
  change_table :your_table do |t|
    t.change :some_column, :integer, after: :other_column
    # ...
  end
end

change_column Połączenia ALTER TABLE pod maską. Z Dokumentacji MySQL :

Możesz również użyć FIRST i AFTER w operacjach CHANGE lub MODIFY do Zmiana kolejności kolumn w tabeli.

 51
Author: Stefan,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-09-19 18:53:32

Rozwiązanie Stefana jest idealne, jeśli masz do czynienia z zaledwie garstką kolumn. Jeśli masz wiele kolumn do ponownego ułożenia i na komputerze Mac, proponuję rzucić okiem na Sequel Pro , sprytne narzędzie do zarządzania bazą danych, które sprawia, że zmiana kolejności kolumn bazy danych jest bardzo prosta. Po prostu przeciągnij i upuść.

PS: nie jestem z nimi związany w żaden sposób.

 -2
Author: Tintin81,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-02-19 11:31:13