Laravel 8 Eloquent updateOrCreate() Example


In this post, we will explain about Laravel Eloquent updateOrCreate () method and its importance in our code. It’s very common that we have database operations in our application, like inserting customer details and updating that customer details at a later stage, or deleting customer details.

For example, you have a function that is responsible for creating a user if he is not existing or updating the user details if he is existing.

Let’s see how we can achieve that in Laravel.

For this example, we have set the email address as a unique field.

$email="[email protected]";
$city  = 'New York';

$user = User::where('email', $email)->first();

   // creates the user
     'email' => $email,
     'phone' => $phone,
     'city'  => $city

     'phone' => $phone,
     'city'  => $city

So far we have done what we have to do to achieve insert / update a user record. Indeed, it’s not a bad solution, but if we have an option for the more elegant solution, would you pick that ?.

Laravel has an elegant method to deal with this situation and that’s the function updateOrCreate (). This function takes the first parameter as the select condition as an array and the second parameter as values ​​that need to be updated as an array.

$user = User::updateOrCreate([
          'email' => $email
    'phone' => $phone',
    'city'  => $city


Please let us know if you have any comments.

Editorial Staff

Editorial Staff at Tutsplanet is a dedicated team to write various tutorials about subjects like Programming, Technology and Operating Systems.



Please enter your comment!
Please enter your name here