如何修复完整性约束违规:1062 键“PRIMARY:Laravel 数据透视表”的重复条目“1-1”

cwd*_*cwd 2 php mysql foreign-keys laravel eloquent

我有一个赞助应用程序,并尝试在用户赞助孩子后将赞助孩子和用户添加到数据透视表中。

  • 孩子可以拥有尽可能多的用户(赞助商),只要他们的插槽允许。
  • 如果需要,用户可以赞助一个孩子、多个孩子或多次赞助同一个孩子

我为赞助者孩子和用户创建了一个数据透视表。在第一个事务中,表中的关系是正确的,但如果用户返回并再次赞助孩子的第二个或第三个插槽,我会收到以下错误:

SQLSTATE[23000]:违反完整性约束:1062 键“PRIMARY”的重复条目“1-1”(23000)

kid_user数据透视表:

public function up()
{
    Schema::create('kid_user', function (Blueprint $table) {
        $table->integer('kid_id')->unsigned()->index();
        $table->foreign('kid_id')->references('id')->on('kids')->onDelete('cascade');
        $table->integer('user_id')->unsigned()->index();
        $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
        $table->primary(['kid_id', 'user_id']);
        $table->timestamps();
    });
}
Run Code Online (Sandbox Code Playgroud)

儿童模型:

  public function users() {
        return $this->belongsToMany(User::class)->withTimestamps();
  }
Run Code Online (Sandbox Code Playgroud)

用户型号:

  public function kids(){
       return $this->belongsToMany(Kid::class)->withTimestamps();
  }
Run Code Online (Sandbox Code Playgroud)

用这一行连接到我的控制器中:

        $cin = $request->cin;
        $kidid = $request->kidid;

        $kids = DB::table('kids')->where('cin', $cin)->increment('sponsors_received');
        $user = Auth::user();
        $user->kids()->attach($kidid);
        //$user->kids()->sync($kidid);
;
Run Code Online (Sandbox Code Playgroud)

我目前得到的:

+--------------------+
|   kid_user table   | 
+--------------------+
| *kid_id | *user_id | * = Primary Key
+---------+----------+
|    1    |     1    | -> Sponsored 1st Slot
+---------+----------+
Run Code Online (Sandbox Code Playgroud)

我想要得到什么:

+--------------------+
|   kid_user table   | THE BELOW RESULTS ARE WHAT I'M LOOKING FOR.
+--------------------+
| *kid_id | *user_id | * = Primary Key
+---------+----------+
|    1    |     1    | -> Sponsored 1st Slot (CURRENTLY GETTING)
+---------+----------+
|    1    |     1    | -> Sponsored 2nd Slot (ERRORS HERE!!!)
+---------+----------+
|    2    |     1    | -> Sponsored 3rd Slot (THIS WILL WORK)
+---------+----------+
Run Code Online (Sandbox Code Playgroud)

我尝试过使用sync而不是attach在我的控制器中使用,但sync只是覆盖第一个关系,而不是添加一个新关系来表示用户正在赞助孩子的 3 个插槽中的第一个和第二个插槽。

还尝试hasMany在我的模型中使用这种关系,但这没有帮助。作为最后一次尝试,我还添加了创建/更新的列,希望能够使其独一无二,但没有运气。

Nab*_*han 5

问题出在数据库设计上。在您的表中,('kid_id','user_id') 集必须是唯一的。但是示例中的第二个 (1,1) 是错误的,因为已经存在一组 (1,1)。

如果您想让同一个用户多次赞助“同一个孩子”,那么您的方法将行不通。您可以使用不同的主键来维护此约束。在这种情况下,它应该是这样的,

| pivot_id*| kid_id | user_id |  * = Primary Key
+---------+---------+----------+
|    1    |    1    |     1    | -> Sponsored 1st Slot (CURRENTLY GETTING)
+---------+---------+----------+
|    2    |    1    |     1    | -> Sponsored 2nd Slot (SAME DATA WITH DIFFERENT KEY)
+---------+---------+----------+
|    3    |    2    |     1    | -> Sponsored 3rd Slot (THIS WILL WORK)
Run Code Online (Sandbox Code Playgroud)