我试图使用ORM的第一次,我已经定义了模型是这样的: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
我得到一个单方面的名单,因为朋友数据库参数可以以任意顺序(user1的用户2的朋友OR用户2为user1的朋友)。如果我尝试使用follow/followers的方法,这样可以,但我希望它是互惠的。
做这种事情的最好方法是什么?在数据库中插入重复的user1/user2和user2/user1听起来不是一个好方法,我甚至不知道如何将其转换为ORM。另外,似乎Friend模型没有被使用/被调用。
我也会在邀请朋友系统上有类似的问题。