Sha256: 8bd642062703979666726111b424866be11715c644442d55c39a9cb82557d126

Contents?: true

Size: 1.52 KB

Versions: 28

Compression:

Stored size: 1.52 KB

Contents

# This migration creates the `versions` table, the only schema PT requires.
# All other migrations PT provides are optional.
class CreateVersions < ActiveRecord::Migration<%= migration_version %>

  # The largest text column available in all supported RDBMS is
  # 1024^3 - 1 bytes, roughly one gibibyte.  We specify a size
  # so that MySQL will use `longtext` instead of `text`.  Otherwise,
  # when serializing very large objects, `text` might not be big enough.
  TEXT_BYTES = 1_073_741_823

  def change
    create_table :versions<%= versions_table_options %> do |t|
      t.string   :item_type<%= item_type_options %>
      t.integer  :item_id,   null: false
      t.string   :event,     null: false
      t.string   :whodunnit
      t.text     :object, limit: TEXT_BYTES

      # Known issue in MySQL: fractional second precision
      # -------------------------------------------------
      #
      # MySQL timestamp columns do not support fractional seconds unless
      # defined with "fractional seconds precision". MySQL users should manually
      # add fractional seconds precision to this migration, specifically, to
      # the `created_at` column.
      # (https://dev.mysql.com/doc/refman/5.6/en/fractional-seconds.html)
      #
      # MySQL users should also upgrade to rails 4.2, which is the first
      # version of ActiveRecord with support for fractional seconds in MySQL.
      # (https://github.com/rails/rails/pull/14359)
      #
      t.datetime :created_at
    end
    add_index :versions, %i(item_type item_id)
  end
end

Version data entries

28 entries across 28 versions & 3 rubygems

Version Path
duty_free-1.0.8 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.7 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.6 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.5 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.4 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.3 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.2 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.1 lib/generators/duty_free/templates/create_versions.rb.erb
duty_free-1.0.0 lib/generators/duty_free/templates/create_versions.rb.erb
paper_trail-9.2.0 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-9.1.1 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-9.1.0 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-9.0.2 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-9.0.1 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-9.0.0 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-8.1.2 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-8.1.1 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-8.1.0 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-8.0.1 lib/generators/paper_trail/templates/create_versions.rb.erb
paper_trail-8.0.0 lib/generators/paper_trail/templates/create_versions.rb.erb