views:

1799

answers:

3

Is there anything explicitly wrong with using has_and_belongs_to_many associations in rails instead of has_many :through? I'm aware of these articles describing differences and work arounds, but they are from 2006. From things I've read on SO, it seems like people think that habtm is old and clunky, but what if a simple many to many join with no model necessary is what you're looking for?

Thoughts?

+11  A: 

has_and_belongs_to_many is meant for simple many-to-many relationships.

has_many :through, on the other hand, is meant for indirect one-to-many relationships, or many-to-many relationships with properties.

If you're only looking for a simple many-to-many relationship, I can't see any reason not to use has_and_belongs_to_many.

Example many-to-many relationship:

User belongs to zero or more groups, and group has zero or more members (users).

Example many-to-many relationship with properties:

User belongs to zero or more groups, and group has zero or more members with ranks.

For example, Alice might be an Administrator in Group A, and a Moderator in Group B. You can hold this property in the join table.

Example indirect one-to-many relationship:

A category has zero or more sub-categories, and each sub-category has zero or more items.

A category therefore has zero or more items through its sub-categories.

Consider these categories:

Food → Fruits, Vegetables
Fruits → Apple, Orange, etc.
Vegetables → Carrot, Celery, etc.

therefore:

Food → Apple, Orange, Carrot, Celery, etc.

Can Berk Güder
To understand recursion you must first understand recursion. I think your answer could be more clear or demonstrative regarding many-to-many relationships with properties vs. many-to-many relationships without properties.
Oliver N.
Let me add some examples.
Can Berk Güder
+1, that actually helped me a lot too.
Oliver N.
+2  A: 

There's nothing wrong with using has_and_belongs_to_many if you don't require a join model. I've just used it myself on a recent project.

John Topley
+2  A: 

I would never use HABTM not because of any concern about elegance but because I can always imagine wanting to add data to a relationship in the future even if I can't see the point now. Being lazy I would like to be able to just add the columns to the join rather than having to rework the relationships and then add the columns.

srboisvert
Never? Really? Like never as in "I never use goto"?
Jason Punyon
I suppose if I could come up with a relationship where it would be logically impossible to add data to it I might choose to go with HABTM. Otherwise, I would go with has_many: through.
srboisvert