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

Como Unir Múltiplos Arquivos PDF em um Único Documento Usando Python

Como Unir Múltiplos Arquivos PDF em um Único Documento Usando Python

No dia a dia, muitas vezes nos deparamos com a necessidade de unir vários arquivos PDF em um único documento.... Leia mais

Extensões Visual Studio Code para o dia a dia

Extensões Visual Studio Code para o dia a dia

Segue uma lista das extensões que mais utilizo em meu dia a dia como desenvolvedor quando uso o editor VisualStudio... Leia mais

Onde aprender React ?

Onde aprender React ?

Vamos lá! Em um dia qualquer estava eu a rolar o feed do Linked-In e um determinado post me chamou... Leia mais

Função PHP para remover tags html de Strings

Função PHP para remover tags html de Strings

Quando trabalhamos com strings que podem conter HTML, é comum nos depararmos com tags mal formatadas, como < p >... Leia mais