HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux vmi1674223.contaboserver.net 5.4.0-182-generic #202-Ubuntu SMP Fri Apr 26 12:29:36 UTC 2024 x86_64
User: root (0)
PHP: 7.4.3-4ubuntu2.22
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //opt/openproject/db/migrate/20190724093332_add_journal_versions_table.rb
require_relative './migration_utils/utils'

class AddJournalVersionsTable < ActiveRecord::Migration[5.2]
  include ::Migration::Utils

  def up
    create_table :journal_versions do |t|
      t.string :journable_type
      t.integer :journable_id
      t.integer :version, default: 0
      t.index %i[journable_type journable_id version],
              name: 'unique_journal_version',
              unique: true
    end

    ActiveRecord::Base.connection.execute <<-SQL
          INSERT INTO journal_versions (journable_type, journable_id, version)
          (SELECT
            journable_type, journable_id, MAX(version)
          FROM journals
          GROUP BY journable_type, journable_id);
    SQL
  end

  def down
    drop_table :journal_versions
  end
end