Laravel 属于多返空

Posted

技术标签:

【中文标题】Laravel 属于多返空【英文标题】:Laravel Belongs to many returning empty 【发布时间】:2021-05-20 11:11:28 【问题描述】:

我在返回属于许多关系时遇到问题。这是我的场景。我有“Individual”模型和“Group”模型,其中每个个人可以属于多个组,每个组可以属于多个用户。使用诸如“localhost/phpmyadmin”之类的数据库蓝图很好,因为我可以单击“group_individual”表上的“组”列,它会返回到“组”表上的相关组。但是在 Laravel 中工作,我得到的是空数组。你能帮我吗?感谢您的宝贵时间。

迁移

Schema::create('groups', function (Blueprint $table) 
    $table->id();
    $table->string('group_id')->unique();
    $table->string('name');
    $table->unsignedBigInteger('members');
    $table->string('url')->nullable();
    $table->timestamps();
);

Schema::create('individuals', function (Blueprint $table) 
    $table->id();
    $table->string('search_id')->unique();
    $table->timestamps();
);

Schema::create('group_individual',function($table)
    $table->id();
    $table->string('group');
    $table->string('individual');
    $table->foreign('group')->references('group_id')->on('groups')->onDelete('cascade');
    $table->string('type');
    $table->foreign('individual')->references('search_id')->on('individuals')->onDelete('cascade');
);

个体模型

public function groups():\Illuminate\Database\Eloquent\Relations\BelongsToMany

    return $this->belongsToMany(Group::class,'group_individual','individual','group');

组模型

public function individuals():\Illuminate\Database\Eloquent\Relations\BelongsToMany

    return $this->belongsToMany(Individual::class,'group_individual','group','individual');

控制器

public function import()
    Individual::create([]);
    Group::create([]);
    \DB::table('group_individual')->insert(['group'=>,'individual'=>,'type'=>]);
    $individual=Individual::find(1);
    dd($individual->groups);

来自上述控制器的$individual->groups 返回空数组。

【问题讨论】:

【参考方案1】:

我找到了解决方案。我尝试使用两个表的 id 而不是自定义其他属性。 这是我使用的代码。我没有使用 DB::insert() 方法,而是使用 attach 方法。

迁移

Schema::create('groups', function (Blueprint $table) 
            $table->id();
            $table->string('group_id')->unique();
            $table->string('name');
            $table->unsignedBigInteger('members');
            $table->string('url')->nullable();
            $table->timestamps();
        );
     
    Schema::create('individuals', function (Blueprint $table) 
                $table->id();
                $table->string('search_id')->unique();
                $table->timestamps();
            );
    Schema::create('group_individual',function($table)
               $table->foreignId('group_id')->constrained()->onDelete('cascade');
               $table->foreignId('individual_id')->constrained()->onDelete('cascade');
               $table->string('type');
            );

个人模特

public function groups(): \Illuminate\Database\Eloquent\Relations\BelongsToMany
    
        return $this->belongsToMany(Group::class,'group_individual','individual_id','group_id');
    

组模型

public function individuals(): \Illuminate\Database\Eloquent\Relations\BelongsToMany
    
        return $this->belongsToMany(Individual::class,'group_individual','group_id','individual_id');
    

控制器

$a=Individual::create();
$b=Group::create();
$a->groups()->attach($b->id);

【讨论】:

【参考方案2】:

看起来你已经反转了 ID 键,尝试在 belongsToMany 方法中切换“组”和“个人”

【讨论】:

我尝试过像“return $this->belongsToMany(Group::class,'group_individual','group','individual');”这样的个人模型,但仍然返回空数组。 可能是个愚蠢的问题,但组、个人和 group_individual 表是否填充了可用于 laravel 的数据? 是的,我有可用的数据。它们都已成功导入,但无法通过代码访问。我已经测试了多对多的关系,只有 id 就像在 Laravel 文档中一样,而不是之前的其他属性。 我不知道是不是因为键是字符串类型或键名。我在玩这些条件。如果您有任何想法,请告诉我。

以上是关于Laravel 属于多返空的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 属于不工作

Laravel 数据透视表属于ToMany

Laravel 搜索属于

Laravel 多对多关系属于用户

属于Parent模型的三个模型的Laravel 8关系

Laravel 一对多(反向)/属于返回 null