1

我创建了一个模型等等,现在我使用该代码获取我的数据:

 $all_keys = MemberAux::select('apikey','apisecret')->where('user_id', $user_id)->first();

该表基本上只有一个自增 id、一个 user_id 和两个数据字段。我输出它们或更新它们

$all_keys->apikey = $apikey_new;
$all_keys->apisecret = $apisecret_new;
$all_keys->save();

效果很好。但是,当记录尚不存在时,我会收到错误消息。现在我阅读了该firstOrCreate方法,但我是一个初学者,我什至不知道我必须在我的选择“字符串”中将它写在哪里。我找到的答案和解决方案暗示了我还没有的知识。

顺便说一句:我正在使用使用 Slim 框架、Laravel 和 Eloquent 的 Userfrosting。

4

2 回答 2

3
 $all_keys = MemberAux::firstOrCreate(
            [
                'user_id' => $user_id
            ],
            [
                'apikey'    => $apikey_new,
                'apisecret' => $apisecret_new
            ]);

在此代码块中, firstOrCreate 中的第一个数组执行 where 查询,查看 user_id 是否存在。如果找到,则从数据库返回该记录,否则使用数组、第一个参数和第二个参数创建新记录。

但在您的情况下,您应该使用updateOrCreate因为您正在获取记录并更新它。

$all_keys = MemberAux::updateOrCreate(
        [
            'user_id' => $user_id
        ],
        [
            'apikey'    => $apikey_new,
            'apisecret' => $apisecret_new
        ]);

背后的逻辑与 firstOrCreate 相同,但在 updateOrCreate 中,您的数据库记录也将更新为第二个参数(数组)中提供的值

于 2019-12-05T09:56:50.490 回答
1

懒惰的方式:

$all_keys = MemberAux::select('apikey','apisecret')->where('user_id', $user_id)->first();
if(!$all_keys){
 $all_keys = new MemberAux();
}
// rest of your code
$all_keys->save();

我认为您正在寻找的方式:

$all_keys = MemberAux::firstOrCreate(['user_id' => $user_id]);
// rest of your code
$all_keys->save();

请注意,您可能必须在模型中设置可填充字段。

于 2019-12-05T09:54:50.447 回答