在 Laravel 6 中,模型应用了软删除后,再次插入记录,唯一键冲突的解决

1、在 Laravel 6 中,模型应用了软删除后,再次插入记录,唯一键冲突。如图1

图1

PS E:\wwwroot\object> php artisan theme-store:theme:install E:\wwwroot\object\resources\views\brooklyn 971c4f4d-097b-4a84-a914-0ef00b6e69da blade --force
删除主题
安装主题到数据仓库
安装失败,因为: SQLSTATE[23000]: Integrity constraint violation: 1062 Duplicate entry '971c4f4d-097b-4a84-a914-0ef00b6e69da-apps/internal/back-top/app.' for key 'theme_asset2_theme_id_asset_key_unique' (SQL: insert into `theme_asset2` (`asset_key`, `theme_id`, `mime_type`, `created_at`, `content`, `schema`, `category`, `updated_at`) values (apps/internal/back-top/app.json, 971c4f4d-097b-4a84-a914-0ef00b6e69da, application/json, 2022-08-26 01:59:53, {
  "title": "回到顶部",
  "description": "为页面增加返回到页面顶部的按钮,提高用户体验。"
}
, ?, unknown, 2022-08-26 01:59:53))

2、原因在于应用了软删除后,当你在模型实例上使用 delete 方法, 当前日期时间会写入 deleted_at 字段。同时,查询出来的结果也会自动排除已被软删除的记录。

ThemeAsset::where('theme_id', $themeId)->delete();

3、由于记录未被硬删除,因此写入新记录时,出现唯一键冲突。

4、查询结果会自动剔除已被软删除的结果。因此,需要使用 withTrashed 方法来获取包括软删除模型在内的模型。再使用 forceDelete 方法,从数据库中永久删除软删除的模型。

ThemeAsset::withTrashed()->where('theme_id', $themeId)->forceDelete();

5、硬删除记录成功,再次插入不再报错。如图2

图2

永夜