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
Laravel Modules and DDD
16 lessons
1 h 59 min
How to Build Laravel 12 API From Scratch
28 lessons
1 h 21 min
NativePHP: Build Mobile App with Laravel
11 lessons
2 h 2 min read