Laravel Eloquent

Laravel
Tempo de leitura: 4 minutos

Laravel Eloquent: O Eloquent ORM (Mapeador Objeto-Relacional) é a forma mais popular de interagir com o banco de dados no Laravel. Ele permite que as tabelas do banco de dados sejam tratadas como classes PHP (Models) e os registros, como instâncias de objetos, eliminando a necessidade de escrever SQL complexo para operações CRUD (Create, Read, Update, Delete).

Este artigo explora a fundo a utilização do Eloquent, desde as convenções até os recursos avançados de Query Scopes.

1. 🏗️ Modelos Eloquent e Convenções

Um Model Eloquent é uma classe que estende Illuminate\Database\Eloquent\Model.

A. Geração

Para criar um novo Model (ex: Post), use o Artisan:

Bash

php artisan make:model Post
# Para criar também Migration, Factory, Controller e Seeder:
php artisan make:model Post -mfcs

B. Convenções Padrão

O Eloquent segue o princípio de “convenção sobre configuração”:

PropriedadeConvenção PadrãoPersonalização
Nome da TabelaPlural do nome do Model em snake case (Ex: User -> users)protected $table = 'meus_usuarios';
Chave Primáriaidprotected $primaryKey = 'codigo';
TimestampsUsa created_at e updated_atpublic $timestamps = false;
ConexãoDB_CONNECTION do .envprotected $connection = 'mysql2';

2. 🔍 Recuperando Dados (Read)

O Eloquent fornece uma API fluente para construir consultas.

MétodoFunçãoExemplo
all()Retorna todos os registros (como uma Collection).$users = User::all();
find()Busca por Chave Primária.$user = User::find(1);
findOrFail()Busca por PK ou lança exceção 404.$user = User::findOrFail(1);
get()Executa a consulta e retorna uma Collection.User::where('active', 1)->get();
first()Retorna apenas o primeiro resultado.User::where('status', 'A')->first();
chunk()Processa grandes resultados em pedaços (otimização de memória).User::chunk(100, function ($users) { /* ... */ });

Exemplo de Filtragem:

PHP

// SELECT * FROM users WHERE active = 1 AND name LIKE '%João%'
$users = User::where('active', 1)
             ->where('name', 'like', '%João%')
             ->orderBy('created_at', 'desc')
             ->get();

3. ✍️ Modificação de Dados (Create, Update, Delete)

A. Inserir (Create)

Você pode instanciar o objeto ou usar o método estático create() (requer a propriedade $fillable no Model).

PHP

// 1. Instanciando e Salvando
$user = new User;
$user->name = 'Novo Usuário';
$user->email = '[email protected]';
$user->save();

// 2. Criação Massiva (Mass Assignment)
User::create([
    'name' => 'Usuário X',
    'email' => '[email protected]',
    'password' => bcrypt('senha'),
]);

B. Atualizar (Update)

PHP

// 1. Atualizando por Objeto (dispara eventos do Model)
$user = User::find(1);
$user->name = 'Nome Atualizado';
$user->save();

// 2. Atualização Massiva (via Query Builder)
User::where('id', 1)->update(['name' => 'Nome Atualizado']);

C. Excluir (Delete)

PHP

// 1. Exclusão por Objeto
$user = User::find(1);
$user->delete();

// 2. Exclusão por Chave(s) Primária(s)
User::destroy(1);
User::destroy([1, 2, 3]);

4. 🗑️ Soft Deletes (Exclusão Suave)

O Soft Deletes (Exclusão Suave) marca um registro como deletado, preenchendo a coluna deleted_at, ao invés de removê-lo fisicamente do banco de dados.

  1. Migration: Adicione a coluna deleted_at.
    PHP
    $table->softDeletes();
  2. Model: Adicione a Trait SoftDeletes.
    PHP
    use Illuminate\Database\Eloquent\SoftDeletes;
    class User extends Model { use SoftDeletes; // ... }
  3. Consultas:
AçãoMétodoEfeito
PadrãoUser::all()Exclui registros deletados dos resultados.
Incluir DeletadosUser::withTrashed()->get()Retorna todos (deletados e não deletados).
Apenas DeletadosUser::onlyTrashed()->get()Retorna apenas os registros deletados.
Restaurar$user->restore()Define deleted_at como NULL.
Deletar Final$user->forceDelete()Remove o registro permanentemente do BD.

5. 🔭 Query Scopes (Escopos de Consulta)

Os Escopos permitem definir conjuntos de restrições de query reutilizáveis e fáceis de chamar.

A. Definindo Escopos Locais

Crie um método no Model prefixado com scope. Ele aceita a instância do Query Builder ($query) como primeiro argumento.

PHP

class User extends Model
{
    // Escopo Simples (ex: status ativo)
    public function scopeActive($query)
    {
        return $query->where('active', 1);
    }

    // Escopo com Parâmetros (ex: busca por nome)
    public function scopeSearchByName($query, $name)
    {
        return $query->where('name', 'like', "%$name%");
    }
}

B. Utilizando Escopos

Chame o escopo como um método do Model, sem o prefixo scope:

PHP

// SELECT * FROM users WHERE active = 1
$activeUsers = User::active()->get();

// SELECT * FROM users WHERE active = 1 AND name LIKE '%João%'
$usersFiltrados = User::active()->searchByName('João')->paginate(10);

✅ Conclusão Laravel Eloquent

Laravel Eloquent: O Eloquent transforma a interação com o banco de dados em uma experiência intuitiva e orientada a objetos. Dominar as convenções, o uso de Soft Deletes e, principalmente, a criação de Query Scopes é fundamental para escrever código Laravel limpo, produtivo e altamente manutenível.

Mas antes de dominar o Laravel, se for o seu caso, toda jornada tem um início. Vamos entender quais são os conhecimentos básicos necessários para aproveitar ao máximo este poderoso framework. Para iniciar seus estudos no Laravel, você precisará dominar as seguintes tecnologias:

HTML
HTML
CSS
CSS
Javascript
JavaScript
SQL
SQL
Capa Curso PHP
PHP

E se você gosta do nosso conteúdo, não deixe de contribuir adquirindo os serviços e produtos dos nossos apoiadores e empresas que somos associados:

Hospedagem Hostinger
Ofertas Amazon
Amazon Prime

Author: Thiago Rossi
Com mais de 20 anos de jornada na tecnologia, minha trajetória evoluiu do ensino técnico à arquitetura de sistemas complexos. Hoje, foco minha expertise no desenvolvimento de soluções de Inteligência Artificial nativa e análise de dados públicos, utilizando o ecossistema PHP para transformar dados brutos em transparência e eficiência. Como autor e desenvolvedor, acredito na democratização do conhecimento. Essa visão resultou em uma biblioteca de mais de 530 artigos gratuitos, cobrindo desde a base do WebDev e Infraestrutura até os bastidores da indústria de Jogos e IA. No universo de Game Design, sou autor do livro "GDD – O Guia Definitivo" e documento ativamente meus processos através de DevLogs, unindo rigor técnico e criatividade em projetos desenvolvidos com GDevelop 5. Meu compromisso é conectar engenharia de ponta com as reais oportunidades do mercado de tecnologia.