PauloRB.dev

Desenvolvedor de Software

Definindo o Ano Atual como Valor Padrão em Migrations do Laravel | PauloRB.dev Definindo o Ano Atual como Valor Padrão em Migrations do Laravel – PauloRB.dev
Definindo o Ano Atual como Valor Padrão em Migrations do Laravel

Definindo o Ano Atual como Valor Padrão em Migrations do Laravel

Ao trabalhar com migrations no Laravel, uma tarefa comum é definir valores padrão para colunas em tabelas de banco de dados. Uma situação específica é definir o ano atual como valor padrão para uma coluna. Este tutorial mostrará como fazer isso de maneira uniforme, independente do banco de dados escolhido, com exemplos específicos para MySQL e PostgreSQL.

Passo 1: Criar a Migration

Primeiro, crie a migration para adicionar a coluna ano à sua tabela. Use o comando Artisan para gerar a migration:

php artisan make:migration add_ano_to_exemplos_table --table=exemplos

No arquivo de migration gerado, adicione a coluna ano com o valor padrão apropriado, dependendo do banco de dados:

Exemplo para MYSQL:

public function up()
{
    Schema::table('exemplos', function (Blueprint $table) {
        $table->integer('ano')->nullable()->default(DB::raw('YEAR(CURDATE())'));
    });
}

public function down()
{
    Schema::table('exemplos', function (Blueprint $table) {
        $table->dropColumn('ano');
    });
}

Exemplo para POSTGRESQL:

public function up()
{
    Schema::table('exemplos', function (Blueprint $table) {
        $table->integer('ano')->nullable()->default(DB::raw('EXTRACT(YEAR FROM CURRENT_DATE)'));
    });
}

public function down()
{
    Schema::table('exemplos', function (Blueprint $table) {
        $table->dropColumn('ano');
    });
}

Exemplo de como definir diretamento no modelo:

namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class Exemplo extends Model
{
    protected static function boot()
    {
        parent::boot();

        static::creating(function ($model) {
            if (is_null($model->ano)) {
                $model->ano = date('Y');
            }
        });
    }
}

Depois de realizado os passos acima execute as migrations

Para garantir que tudo está funcionando conforme o esperado, você pode testar criando um novo registro na tabela exemplos. No Tinker ou em um controlador, crie um novo registro sem especificar o valor da coluna ano:

use App\Models\Exemplo;

$newRecord = Exemplo::create([
    'status' => 'AGUARDANDO'
]);

echo $newRecord->ano; // Deve exibir o ano atual

Mais Posts

Como iniciar, parar e reiniciar o Apache Web Server no Linux

Como iniciar, parar e reiniciar o Apache Web Server no Linux

Comandos  para controlar o funcionamento do apache em ambientes de desenvolvimento locais: Estes Comandos Servem para ambientes Ubuntu/Debian: Leia mais

Manipulando dados de arrays com o método ‘pluck’ em coleções do Laravel

Manipulando dados de arrays com o método ‘pluck’ em coleções do Laravel

O Laravel é um dos frameworks de desenvolvimento web mais populares e poderosos em uso atualmente. Ele tem muitas características... Leia mais

Um resumo sobre o WSL2

Um resumo sobre o WSL2

O WSL 2 (Windows Subsystem for Linux) representa um grande avanço na integração entre o Windows e o Linux, permitindo... Leia mais

Construir array de texto a partir de um array.

Construir array de texto a partir de um array.

No dia de hoje(17/08/2022) me deparei com o seguinte problema onde recebiamos um array javascript contendo textos e cujas chaves... Leia mais