如何修复完整性约束违规:1062 键“PRIMARY:Laravel Pivot Table”的重复条目“1-1”

Posted

技术标签:

【中文标题】如何修复完整性约束违规:1062 键“PRIMARY:Laravel Pivot Table”的重复条目“1-1”【英文标题】:How to fix Integrity constraint violation: 1062 Duplicate entry '1-1' for key 'PRIMARY: Laravel Pivot Table 【发布时间】:2019-06-10 03:58:56 【问题描述】:

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

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

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

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

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();
    );

童模:

  public function users() 
        return $this->belongsToMany(User::class)->withTimestamps();
  

用户模型:

  public function kids()
       return $this->belongsToMany(Kid::class)->withTimestamps();
  

用这条线附加到我的控制器中:

        $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);
;

我目前得到的:

+--------------------+
|   kid_user table   | 
+--------------------+
| *kid_id | *user_id | * = Primary Key
+---------+----------+
|    1    |     1    | -> Sponsored 1st Slot
+---------+----------+

我想要得到什么:

+--------------------+
|   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)
+---------+----------+

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

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

【问题讨论】:

同步添加你的控制器逻辑。 根据您的要求更新了问题。上面只是条带事务逻辑。这确实是一个后续问题:***.com/questions/54153547/… kid_id 应该是(kids 表的)外键,而不是kid_user 表中的主键。 有什么原因不能为 Kid_user 表使用正常递增的 id 吗?您当前的主要是引发错误的原因。 所以kid_user表只是一个关系表,所以不需要为增量目的维护主键。 【参考方案1】:

问题在于数据库设计。在您的表中, ('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)

【讨论】:

好吧,这是有道理的。所以在我的 Kid_user 表中,我应该简单地添加一个 id 列并删除 $table->primary(['kid_id', 'user_id']); ... 对吗? 是的。之后,Laravel 应该不会显示此错误。 @NabilFarhan 在关系表中维护 pivot_id 的主要目的是什么?不加这个字段能解决吗?【参考方案2】:

是的,我同意@Nabil 的回答。数据库设计有问题。由于 db 表中的唯一约束,应用程序抛出错误。要么采用他建议的方法,要么您也可以添加计数字段。我想,你想知道一个孩子得到了多少赞助?使所有这些字段唯一(kid_id、user_id、slots)

【讨论】:

我在考虑 slot 列并且可能会这样做,因为我在 kids 表中有一个 slot_needed 列,但我认为@Nabil 的回答会满足我的需要。感谢您的反馈!

以上是关于如何修复完整性约束违规:1062 键“PRIMARY:Laravel Pivot Table”的重复条目“1-1”的主要内容,如果未能解决你的问题,请参考以下文章

Laravel:完整性约束违规:1062重复条目'jon@doe.com'键'users_email_unique'

SQLSTATE [23000]:完整性约束违规:1062 键 'tbl_item_item_ID_UNIQUE' 的重复条目 '25'

Laravel - SQLSTATE [23000]:完整性约束违规:1062 键“posts_user_id_unique”的重复条目“1”

修复了Innodb完整性约束违规:1452 [重复]

在 symfony2 中处理 1062 重复条目异常

SQLSTATE[23000]:完整性约束违规 1452 无法添加或更新子行:外键约束失败