gpt4 book ai didi

php - 使用 Laravel 避免重复输入约束冲突

转载 作者:行者123 更新时间:2023-11-30 22:12:55 26 4
gpt4 key购买 nike

我有一个用于用户设备的 mySQL 表,其中有一列 device_id,它分配了一个 UNIQUE 约束。

在我的 Laravel 应用程序中,我的 APIController 类提供了一个 API 来将新设备添加到表中。该方法如下所示:

public function postDevice(Request $request)
{
$user = Auth::user();

if(!$request->has('device_id'))
return response()->json(['error' => 'You need to provide a unique device identifier "device_id".'], 460);

$device_id = $request->input('device_id');

$device = UserDevice::where('device_id', $device_id)->first();

if($device) {
// update device properties with transmitted data
$device->fill($request->all());

// make sure this device belongs to our user
$device->user()->associate($user);

$device->save();
} else {
// create new device for our user
$user->devices()->create($request->all());
}

return response()->json(['status'=>'success']);
}

我认为我的条件将确保不会通过此 API 违反唯一性约束。但不知何故,我经常会遇到这样的错误:

Integrity constraint violation: 1062 Duplicate entry 'C02P69YWG3QC' for key 'user_devices_device_id_unique' (SQL: insert into 'user_devices' ('device_id', 'mac_model', 'mail_version', 'mailbutler_version', 'osx_version', 'user_id', 'updated_at', 'created_at') values (C02P69YWG3QC, MacBook Pro (Retina, 15-inch, Late 2013), 10.0 (3225), 6439, 10.12.0, 13400, 2016-09-13 12:17:56, 2016-09-13 12:17:56))

您知道上面显示的代码如何违反约束吗?是否有更好的编码范例来避免此类错误?

顺便说一句:我正在运行这个应用程序,可能有多个实例在同一个数据库上工作。会不会涉及竞争条件?

最佳答案

为什么不使用验证?

$this->validate($request, [
'device_id' => 'bail|required|unique:user_devices',
]);

关于php - 使用 Laravel 避免重复输入约束冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39471296/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com