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

Usando a Função ROW_NUMBER e Outras Funções para Gerar Resultados Sequenciais no PostgreSQL

Usando a Função ROW_NUMBER e Outras Funções para Gerar Resultados Sequenciais no PostgreSQL

Quando trabalhamos com bancos de dados, muitas vezes precisamos gerar números sequenciais para nossos resultados. Isso pode ser útil para... Leia mais

Como Instalar o PostgreSQL 16 no Linux Mint 21

Como Instalar o PostgreSQL 16 no Linux Mint 21

O PostgreSQL 16 ainda não está disponível nos repositórios oficiais do Linux Mint 21, então usaremos o repositório oficial do... Leia mais

Alternar entre múltiplas versões no PHP

Alternar entre múltiplas versões no PHP

Então problemas do dia-a-dia se por alguma motivo qualquer você prefere utilizar ambientes de desenvolvimento locais ao invés de containers... Leia mais

Função para fazer a tecla ENTER funcionar como a tecla TAB em formulários web.

Função para fazer a tecla ENTER funcionar como a tecla TAB em formulários web.

Segue função em Jquery que utilizei muito em projetos para permitir o comportamento da tecla TAB(pular campos do formulários) utilizando... Leia mais