ORM:友谊/好友关系

Posted

技术标签:

【中文标题】ORM:友谊/好友关系【英文标题】:ORM: friendship/buddylist relationship 【发布时间】:2012-10-28 22:56:06 【问题描述】:

我是第一次尝试使用 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 是 user2 的好友 OR user2 是 user1 的好友)。如果我尝试使用追随者/追随者方法,这将是可以的,但我希望它是互惠的。

做这种事情的最佳方法是什么?在数据库上插入重复的 user1/user2 和 user2/user1 听起来不是一个好方法,我什至不知道如何将其转换为 ORM。此外,似乎 Friend 模型根本没有被使用/被调用。

我也会在邀请好友系统上遇到类似的问题。

【问题讨论】:

【参考方案1】:

您正在寻找用户之间的多对多关系! 看看你如何在 Doctrine 中做到这一点:Doctrine - Many to Many Self Referencing。 教义示例可能会帮助您入门。

这个想法是你有一个实体,用户,他们可以互相成为朋友。

【讨论】:

以上是关于ORM:友谊/好友关系的主要内容,如果未能解决你的问题,请参考以下文章

SQL 选择好友查询

Laravel ORM 友谊关系不重复

Cakephp互惠好友系统

讲真,微信讨红包测友谊的人都是傻逼

查询以了解以下内容

关于友谊的残酷真相