Database Operations Examples
Examples for database CRUD operations.
Introduction
Section titled “Introduction”Common database patterns:
- ✅ Create - Insert new records
- ✅ Read - Fetch records
- ✅ Update - Update records
- ✅ Delete - Delete records
- ✅ Relationships - Handle relationships
Create (Insert)
Section titled “Create (Insert)”class CreateUserDTO extends SimpleDTO{    public function __construct(        #[Required, Min(3)]        public readonly string $name,
        #[Required, Email]        public readonly string $email,
        #[Required, Min(8)]        public readonly string $password,    ) {}}
$dto = CreateUserDTO::validateAndCreate($_POST);
$user = User::create([    'name' => $dto->name,    'email' => $dto->email,    'password' => password_hash($dto->password, PASSWORD_DEFAULT),]);
// Or use toModel()$user = $dto->toModel(User::class);$user->save();Read (Fetch)
Section titled “Read (Fetch)”class UserDTO extends SimpleDTO{    public function __construct(        public readonly int $id,        public readonly string $name,        public readonly string $email,        public readonly Carbon $createdAt,    ) {}}
// Single record$user = User::find(1);$dto = UserDTO::fromModel($user);
// Multiple records$users = User::all();$dtos = $users->map(fn($user) => UserDTO::fromModel($user));
// With DataCollection$dtos = DataCollection::make($users, UserDTO::class);Update
Section titled “Update”class UpdateUserDTO extends SimpleDTO{    public function __construct(        public readonly ?string $name = null,        public readonly ?string $email = null,    ) {}}
$dto = UpdateUserDTO::validateAndCreate($_POST);
$user = User::find($id);
// Only update provided fields$data = array_filter($dto->toArray(), fn($v) => $v !== null);$user->update($data);
// Or use toModel()$dto->toModel($user);$user->save();Delete
Section titled “Delete”$user = User::find($id);
// Check permissionsif (auth()->user()->can('delete', $user)) {    $user->delete();}Relationships
Section titled “Relationships”One-to-Many
Section titled “One-to-Many”class PostDTO extends SimpleDTO{    public function __construct(        public readonly int $id,        public readonly string $title,        public readonly string $content,        public readonly UserDTO $author,        public readonly array $comments,    ) {}}
$post = Post::with(['author', 'comments'])->find(1);$dto = PostDTO::fromModel($post);Many-to-Many
Section titled “Many-to-Many”class UserDTO extends SimpleDTO{    public function __construct(        public readonly int $id,        public readonly string $name,        public readonly array $roles,    ) {}}
$user = User::with('roles')->find(1);$dto = UserDTO::fromModel($user);Pagination
Section titled “Pagination”class PaginatedUsersDTO extends SimpleDTO{    public function __construct(        public readonly array $data,        public readonly int $currentPage,        public readonly int $lastPage,        public readonly int $total,    ) {}}
$users = User::paginate(20);
$dto = PaginatedUsersDTO::fromArray([    'data' => $users->map(fn($u) => UserDTO::fromModel($u))->toArray(),    'currentPage' => $users->currentPage(),    'lastPage' => $users->lastPage(),    'total' => $users->total(),]);Filtering
Section titled “Filtering”class UserFilterDTO extends SimpleDTO{    public function __construct(        public readonly ?string $name = null,        public readonly ?string $email = null,        public readonly ?string $role = null,        public readonly ?Carbon $createdAfter = null,    ) {}}
$filter = UserFilterDTO::fromArray($_GET);
$users = User::query()    ->when($filter->name, fn($q) => $q->where('name', 'like', "%{$filter->name}%"))    ->when($filter->email, fn($q) => $q->where('email', $filter->email))    ->when($filter->role, fn($q) => $q->whereHas('roles', fn($q) => $q->where('name', $filter->role)))    ->when($filter->createdAfter, fn($q) => $q->where('created_at', '>=', $filter->createdAfter))    ->get();Bulk Operations
Section titled “Bulk Operations”Bulk Insert
Section titled “Bulk Insert”$dtos = [    CreateUserDTO::fromArray(['name' => 'John', 'email' => 'john@example.com']),    CreateUserDTO::fromArray(['name' => 'Jane', 'email' => 'jane@example.com']),];
$data = array_map(fn($dto) => $dto->toArray(), $dtos);
User::insert($data);Bulk Update
Section titled “Bulk Update”User::whereIn('id', [1, 2, 3])->update(['status' => 'active']);Transactions
Section titled “Transactions”DB::transaction(function() use ($dto) {    $user = User::create($dto->toArray());
    $profile = Profile::create([        'user_id' => $user->id,        'bio' => $dto->bio,    ]);
    $user->roles()->attach($dto->roleIds);});Soft Deletes
Section titled “Soft Deletes”// Soft delete$user = User::find($id);$user->delete();
// Restore$user = User::withTrashed()->find($id);$user->restore();
// Force delete$user->forceDelete();Eager Loading
Section titled “Eager Loading”class PostDTO extends SimpleDTO{    public function __construct(        public readonly int $id,        public readonly string $title,        public readonly UserDTO $author,        public readonly array $comments,        public readonly array $tags,    ) {}}
$posts = Post::with(['author', 'comments', 'tags'])->get();$dtos = $posts->map(fn($post) => PostDTO::fromModel($post));See Also
Section titled “See Also”- Creating DTOs - DTO creation methods
- Nested DTOs - Nested DTOs
- Collections - DataCollection
