If you have DB column which you want to be set only once and never updated again, you can set that restriction on Eloquent Model, with a mutator:
- In version 9 and above:
use Illuminate\Database\Eloquent\Casts\Attribute; class User extends Model{ protected function email(): Attribute { return Attribute::make( set: fn ($value, $attributes) => $attributes['email'] ?? $value, ); }}
- In version 9 and below:
class User extends Model{ public function setEmailAttribute($value) { if (isset($this->attributes['email']) && ! is_null($this->attributes['email'])) { return; } $this->attributes['email'] = $value; }}
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
How to Build Laravel 12 API From Scratch
28 lessons
1 h 21 min
Claude Code for Laravel Projects: Crash Course
8 lessons
48 min
NativePHP: Build Mobile App with Laravel
11 lessons
2 h 2 min read