Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Active Record has_many :through remove one associated record

This may be a very basic oversight on my part, but I can't seem to recall a simple method for removing an association between two objects joined via has_many :through. IE:

class Photo
  has_many :tags, :through => :taggings
  has_many :taggings, :dependent => :destroy
end

class Tags
  has_many :photos, :through => :taggings
  has_many :taggings, :dependent => :destroy
end

class Taggings
  belongs_to :photo
  belongs_to :tag
end

If you have two objects, tag and photo, you can associate them just by doing this:

photo.tags << tag

So, is there an equally simple opposite to this? ie:

photo.tags.remove tag
like image 899
Andrew Avatar asked Nov 04 '12 05:11

Andrew


1 Answers

here's what you want:

photo.tags.delete(tag)
like image 117
aguynamedloren Avatar answered Oct 17 '22 23:10

aguynamedloren