PauloRB.dev

Desenvolvedor de Software

Converter campos de um banco de dados do tipo json para array com laravel | PauloRB.dev Converter campos de um banco de dados do tipo json para array com laravel – PauloRB.dev
Converter campos de um banco de dados do tipo json para array com laravel

Converter campos de um banco de dados do tipo json para array com laravel

Hoje boa parte dos banco de dados relacionais podem armazenar campos com valores no formato JSON o que garante maior confiabilidade no tipo de dado armazenado substituindo uma antiga prática de se guardar estes em formatos que foram originalmente concebidos para strings.

Uma prática que eu adotei até pouco tempo atrás para estas situações foi usar um método do tipo mutator no laravel e fazer a conversão manualmente como mostrado abaixo:

public function getCamposPersonalizadosAttribute($value)
{
       return is_null($value) ? null : json_decode($value);
}

Abaixo apresento uma forma de converter o tipo de json em array no Laravel de uma forma mais limpa e prática através do método $casts.

class SeuModel extends Model

{

protected $casts = [

    ‘nome_do_campo_json’ => ‘array’,

     // Adicione mais campos aqui, se necessário ];

}

O recurso $casts do Laravel é usado para especificar a conversão automática de tipos de dados em um model. Ele permite que você defina atributos no seu model para serem automaticamente convertidos de  para tipos de dados específicos, como array, JSON, booleano, data e hora, e assim por diante.

Abaixo mais alguns exemplos de uso do método $casts:

class SeuModel extends Model

{

protected $casts = [

                  ‘nome_do_campo_json’ => ‘array’,

                  ‘outro_campo_json’ => ‘json’,

                  ‘campo_booleano’ => ‘boolean’,

                 // Adicione mais atributos e tipos de dados aqui, se necessário ];

 // … }

Tipos de dados suportados: O Laravel suporta vários tipos de dados para conversão, incluindo:

  • array: Converte o valor para um array associativo.
  • json: Converte o valor para uma string JSON.
  • boolean: Converte o valor para um booleano.
  • integer: Converte o valor para um inteiro.
  • float: Converte o valor para um número de ponto flutuante.
  • date: Converte o valor para um objeto Carbon que representa uma data.
  • datetime: Converte o valor para um objeto Carbon que representa uma data e hora.
  • collection: Converte o valor para uma coleção do Laravel.

Em resumo, o uso do recurso $casts do Laravel é uma forma eficiente e prática de lidar com a conversão automática de tipos de dados em um model, quando se trabalha com campos JSON em bancos de dados relacionais. Isso elimina a necessidade de métodos mutators e permite uma implementação mais limpa e organizada do código. Com os diversos tipos de dados suportados pelo Laravel, é possível facilmente converter os valores armazenados em campos JSON para os tipos de dados desejados, como arrays, booleanos, inteiros, entre outros. A utilização do $casts ajuda a garantir a integridade e confiabilidade dos dados armazenados, tornando o desenvolvimento com Laravel mais eficiente e eficaz.

Mais Posts

Instalando e Gerenciando o SQLite no Linux

Instalando e Gerenciando o SQLite no Linux

Introdução ao SQLite O SQLite é um sistema de banco de dados leve, sem servidor e autocontido, amplamente utilizado em... Leia mais

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

Tutorial: Exportando Imagens Base64 Usando Laravel Excel

Tutorial: Exportando Imagens Base64 Usando Laravel Excel

Neste tutorial, vamos aprender como exportar uma lista de cadastros de clientes para uma planilha Excel, incluindo as fotos dos... Leia mais

Como instalar a Linguagem ELIXIR no Linux.

Como instalar a Linguagem ELIXIR no Linux.

Elixir é uma linguagem de programação dinâmica e funcional, desenvolvida por José Valim em 2011, projetada para construir aplicações escaláveis... Leia mais