Sha256: 87eba25789cdb8100e513e7fb6e6d0973338d1a6835f7f91667f2bdcfbdb22aa

Contents?: true

Size: 1.31 KB

Versions: 1

Compression:

Stored size: 1.31 KB

Contents

# frozen_string_literal: true

class CreateRatingTables < ActiveRecord::Migration[5.0]
  def change
    create_table :rating_rates do |t|
      t.decimal :value, default: 0, precision: 17, scale: 14

      t.references :author   , index: true, null: false, polymorphic: true
      t.references :resource , index: true, null: false, polymorphic: true
      t.references :scopeable, index: true, null: true , polymorphic: true

      t.timestamps null: false
    end

    add_index :rating_rates, %i[author_id author_type resource_id resource_type scopeable_id scopeable_type],
      name:   :index_rating_rates_on_author_and_resource_and_scopeable,
      unique: true

    create_table :rating_ratings do |t|
      t.decimal :average , default: 0, mull: false, precision: 17, scale: 14
      t.decimal :estimate, default: 0, mull: false, precision: 17, scale: 14
      t.integer :sum     , default: 0, mull: false
      t.integer :total   , default: 0, mull: false

      t.references :resource , index: true, null: false, polymorphic: true
      t.references :scopeable, index: true, null: true , polymorphic: true

      t.timestamps null: false
    end

    add_index :rating_ratings, %i[resource_id resource_type scopeable_id scopeable_type],
      name:   :index_rating_rating_on_resource_and_scopeable,
      unique: true
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
rating-0.2.0 lib/generators/rating/templates/db/migrate/create_rating_tables.rb