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
Building a Typical Laravel SaaS
13 lessons
1 h 58 min
Laravel Coding with AI Agents: Cursor, Claude Code, Codex
5 lessons
1 h 01 min
How to Build Laravel 12 API From Scratch
28 lessons
1 h 21 min