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

Entendendo a Função list() no PHP

Entendendo a Função list() no PHP

A função list() do PHP é uma forma prática de atribuir múltiplos valores de um array a variáveis individuais. Neste... Leia mais

Como instalar o Docker no Linux(Ubuntu)

Como instalar o Docker no Linux(Ubuntu)

Para instalar o docker no ubuntu basta seguir os passos abaixo: Abra o terminal do Linux copie e cole os... Leia mais

Converter Date Time String para data no formato YYYY-MM-DD

Converter Date Time String para data no formato YYYY-MM-DD

No post de hoje, vamos abordar uma necessidade comum em programação: como obter uma data no formato ANO-MÊS-DIA (YYYY-MM-DD) a... Leia mais

Script para automatizar as instalações de extensões do php em distribuições LINUX

Script para automatizar as instalações de extensões do php em distribuições LINUX

Publiquei neste artigo https://paulorb.dev/alternar-entre-multiplas-versoes-no-php/ formas de como instalar diversas versões do PHP em distros Linux mas surgiu um problema que... Leia mais