我第一次尝试使用ORM,我已经定义了这样的模型:
用户模型:
class User extends Eloquent
{
public function friends()
{
return $this->has_many_and_belongs_to('User', 'friends', 'user1_id', 'user2_id');
}
}
朋友模特:
class Friend extends Eloquent
{
public function friend()
{
return $this->belongs_to('User', 'user_id');
}
}
朋友mysql表:
id (pkey) # user1_id (references users.user_id) # user2_id (references users.user_id)
现在使用$user->friends
我得到一个单边列表,因为friends数据库参数可以是任何顺序(user1是user2的朋友 OR user2是user1的朋友)。如果我试图使用跟随/追随者的方法,那就没关系,但我希望它是互惠的。
做这种事情的最佳方法是什么?在数据库上插入重复的user1 / user2和user2 / user1听起来不是一个好方法,我甚至不知道如何将其转换为ORM。此外,似乎Friend模型根本没有被使用/被调用。
我也会在邀请朋友系统上遇到类似的问题。
答案 0 :(得分:2)
您正在寻找用户之间的多对多关系! 在Doctrine中查看如何执行此操作:Doctrine - Many to Many Self Referencing。 Doctrine示例可能会帮助您入门。
这个想法是你有一个实体,用户,他们可以成为彼此的朋友。