This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the databases category.
Last Updated: 2025-01-18
I was having an issue with a hasManyThrough
relationship code in an ORM - I
could not get my user to have many slots through tickets using their library.
Basically I had: - a User object - a (time) Slot object - a Ticket object with userid and slotid (i.e. a User has many tickets and a Slot also has many tickets)
A user has_many tickets - no problem. But I could not get a user to have many slots THROUGH tickets.
I got unstuck upon realizing a hasManyThrough can be done as a hasAndBelongsToMany relationship, with the intermediary (ticket) being the join table. Luckily for me, the ORM code worked in this branch.
How exactly do I know this? Well consider how the following shows a pivot table embedded inside the tickets data.
ticket id=1 (slot_id=1, user_id=1) price=12.00
ticket id=1 (slot_id=1, user_id=2) pirce=14.00