Using DB::afterCommit method you can write code that will only be executed if the transaction gets committed and discarded if the transaction is rolled back.
If there is no transaction, the code will be executed right away.
DB::transaction(function () { $user = User::create([...]); $user->teams()->create([...]);});
class User extends Model{ protected static function booted() { static::created(function ($user) { // Will send the email only if the // transaction is committed DB::afterCommit(function () use ($user) { Mail::send(new WelcomeEmail($user)); }); }); }}
Tip given by @cosmeescobedo
Enjoyed This Tip?
Get access to all premium tutorials, video and text courses, and exclusive Laravel resources. Join our community of 10,000+ developers.
Recent Courses
PhpStorm Junie AI for Laravel Projects: Crash Course
7 lessons
36 min
NativePHP: Build Mobile App with Laravel
11 lessons
2 h 2 min read
Laravel HTTP Client and 3rd-Party APIs
7 lessons
50 min