0

我想知道我应该如何与包含两个单词的类/表建立多对多关系。

我用迁移制作了一个名为“image_codes”的数据库表。我希望一个“用户”能够拥有许多“图像代码”,而一个“图像代码”可以拥有许多“用户”。所以我的问题是我应该如何建立这种关系以及我的模型应该被称为什么。

多对多表的名称是“image_code_user”

当我尝试这个时:

class ImageCode extends Eloquent {
    public $table = 'image_codes';

    public function users()
    {
        return $this->belongsToMany('User', 'image_code_user');
    }
}

class User extends Eloquent {
    public $table = 'users';

    public function image_codes()
    {
        return $this->belongsToMany('ImageCode', 'image_code_user');
    }
}


/**
 * The result below this lines....
 **/

$user = User::find(1);
var_dump($user->image_codes) 
// Outcome is NULL

我尝试了很多不同的方法,但总是相同的结果,如果我成功了,它就会起作用。

$image_code = ImageCode::find(1);
var_dump($image_code->users) 
// All users were returned

现在我开始怀疑我的表 image_codes 是否有问题,是否可以使用包含两个谈论“ImageCode”的单词的单词。所以我试图重新制作所有东西,但后来改用“代码”这个名字。

多对多表的名称是“code_user”

class Code extends Eloquent {
    public $table = 'codes';

    public function users()
    {
        return $this->belongsToMany('User', 'code_user');
    }
}

class User extends Eloquent {
    public $table = 'users';

    public function image_codes()
    {
        return $this->belongsToMany('Code', 'code_user');
    }
}


/**
 * The result below this lines....
 **/

$user = User::find(1);
var_dump($user->codes) 
// All codes were returned

所以请堆栈溢出。有人能告诉我应该如何与“ImageCode”和“User”这个词建立正确的多对多关系吗

谢谢指教!

4

1 回答 1

0

http://doc.laravelbook.com/eloquent/#one-to-one

根据文档,在 User 模型中,belongsToMany 函数的第二个参数用于定义 Image_Codes 表的外键,而不是我假设您在这里尝试做的中间/数据透视表/中间表的名称.

现在你有两个模型:ImageCode 和 User。

Laravel 默认将这两个模型的名称组合为数据透视表的名称,在本例中为 imagecode_user。

您可以先尝试删除 belongsToMany 函数的第二个参数,然后将数据透视表重命名为 imagecode_user。

如果您坚持将数据透视表命名为 image_code_user,请将您的 ImageCode 模型重命名为 Image_Code。

当然,完美的解决方案是将数据透视表名称定义为 image_code_user 并拥有两个名为 ImageCode 和 User 的模型,因为编写 ImageCode::find(1) 然后编写 Image_Code::find(1) 要优雅得多。不幸的是,我对此没有答案。

于 2013-06-16T14:57:16.393 回答