I just created a counter_cache field and the controller looks like this.
@users = User.where(:sex => 2).order('received_likes_count')
The association in User.rb is
has_many :received_likes, :through => :attachments, :source => :likes, :dependent => :destroy
Problem is that counter_cache is declared in the belong_to of Like.rb and I don't know how to tell it that is for the has_many :through association.
belongs_to :user, :counter_cache => :received_likes
You have previous
class Product has_and_belongs_to_many :categories end class Category has_and_belongs_to_many :products end
and migration
class CreateCategoriesProducts < ActiveRecord::Migration def change create_table :categories_products, id: false do |t| t.references :category t.references :product end add_index :categories_products, [:category_id, :product_id] end end
now change all to
class Product has_many :categories_products, dependent: :destroy has_many :categories, through: :categories_products end class Category has_many :categories_products, dependent: :destroy has_many :products, through: :categories_products end
and new one
class CategoriesProduct < ActiveRecord::Base # this model uses table "categories_products" as it is # column products_count is in the table "categories" belongs_to :category, counter_cache: :products_count belongs_to :product end
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With