Ir para conteúdo
CamilaDePaula

Como fazer um insert no campo date em pt_BR com PHP?

Recommended Posts

Olá!

Preciso de uma ajuda, por favor... tenho um campo do tipo Date no banco, mas preciso que no formulário o usuário digite no formato que usamos no Brasil.

Para converter, estou fazendo o insert, com o auxilio do seguinte código:

 

$data_operacao2 = implode("-", array_reverse(explode("/", $data_operacao2)));

 

Só que ele está bagunçando um pouco a data na hora de inserir no banco.

Por exemplo:

1 - se digito  28/02/2017 (yyyy) ele grava no banco  0000-00-00

2-  se digito 28/02/17 (yy) ele grava no banco  2028-02-17 (fica meio assim yydd/mm/yy)

 

Como posso corrigir isso?

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Dá um echo na variável $data_operacao2 antes de inserir no BD para ver o valor real da variável após a alteração.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Eu utilizo esta configuração sem problema, seta o campo como date e defini 0000-00-00 , não bagunça e fica certinho.

Porém faça como nosso amigo falou, da um echo e verifique.

Compartilhar este post


Link para o post
Compartilhar em outros sites
$dataCrua           = "2017-02-21";
$dataFormatada = date('d/m/Y', strtotime($dataCrua));
echo $dataFormatada;

 

Ta ai um exemplo de como tratar data vinda em outros formatos.

Lembrando que no BD em campo DATE você precisa salvar no formato "universal" YYYY-MM-DD

Sempre salve em YYYY-MM-DD e na impressão você faz a tratativa como te mostrei acima

  • -1 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 21/02/2017 at 12:47, Guilherme Luiz disse:

$dataCrua           = "2017-02-21";
$dataFormatada = date('d/m/Y', strtotime($dataCrua));
echo $dataFormatada;

 

Ta ai um exemplo de como tratar data vinda em outros formatos.

Lembrando que no BD em campo DATE você precisa salvar no formato "universal" YYYY-MM-DD

Sempre salve em YYYY-MM-DD e na impressão você faz a tratativa como te mostrei acima

 

 

Obrigada pela resposta, mas não entendi muito bem o que voce postou.

Eu sei que o formato do campo Date é  YYYY-MM-DD, e é exatamente este o problema. Preciso tratar o campos para o envio, antes de tratar para a impressão.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Em 21/02/2017 at 11:01, gersonab disse:

Eu utilizo esta configuração sem problema, seta o campo como date e defini 0000-00-00 , não bagunça e fica certinho.

Porém faça como nosso amigo falou, da um echo e verifique.

 

O campos já está setado como date, mas não entendi a parte que você disse "defini 0000-00-00". Onde eu defino assim?

Em 21/02/2017 at 10:30, ESerra disse:

Dá um echo na variável $data_operacao2 antes de inserir no BD para ver o valor real da variável após a alteração.

 

Dei um echo após a alteração, e apareceu errado como no exemplo que citei. O que devo fazer? 

Compartilhar este post


Link para o post
Compartilhar em outros sites
7 minutos atrás, CamilaDePaula disse:

 

O campos já está setado como date, mas não entendi a parte que você disse "defini 0000-00-00". Onde eu defino assim?

 

Dei um echo após a alteração, e apareceu errado como no exemplo que citei. O que devo fazer? 

$data_operacao2 = '21/10/1984';
$data_operacao2 = implode("-", array_reverse(explode("/", $data_operacao2)));
echo $data_operacao2; //Resultado 1984-10-21

Logo o problema está no formato da sua data e não na conversão.

  • +1 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
6 minutos atrás, ESerra disse:

$data_operacao2 = '21/10/1984';
$data_operacao2 = implode("-", array_reverse(explode("/", $data_operacao2)));
echo $data_operacao2; //Resultado 1984-10-21

Logo o problema está no formato da sua data e não na conversão.

 

Como posso arrumar?

Compartilhar este post


Link para o post
Compartilhar em outros sites
Agora, CamilaDePaula disse:

 

Como posso arrumar?

 

 

Informe a data no formato correto... a data de entrada deverá ser dd/mm/aaaa. Se for outro formato a conversão não vai funcionar como esperado.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Agora, ESerra disse:

 

 

Informe a data no formato correto... a data de entrada deverá ser dd/mm/aaaa. Se for outro formato a conversão não vai funcionar como esperado.

 

Mas estou informando a data no formato correto. Como eu disse, acontece seguinte:

 

1 - se digito  28/02/2017 (yyyy) ele grava no banco  0000-00-00 (assim com zero mesmo, sem a data)

2-  se digito 28/02/17 (yy, no caso o ano só com duas casas) ele grava no banco  2028-02-17 (fica meio assim yydd/mm/yy)

Compartilhar este post


Link para o post
Compartilhar em outros sites

Vamos tenta um novo aproach, pensar:

 

Me responde, porque motivo o BD está gravando 0000-00-00?

Compartilhar este post


Link para o post
Compartilhar em outros sites
4 minutos atrás, ESerra disse:

Vamos tenta um novo aproach, pensar:

 

Me responde, porque motivo o BD está gravando 0000-00-00?

 

Talvez porque esteja pegando um formato inválido, ou talvez seja algum erro no INSERT, mas não sei...

Compartilhar este post


Link para o post
Compartilhar em outros sites

Esse é o primeiro problema "talvez"... talvez é a mãe de todos os erros, você tem que entender o que está fazendo para só assim corrigir o problema.

 

Está sendo inserido 0000-00-00 porque o formato da data está fora do padrão que o campo exige.

 

Então, ANTES do insert, dê um echo na variável e veja o que de fato está sendo passado para o insert, esse será o ponto de partida.

Compartilhar este post


Link para o post
Compartilhar em outros sites
26 minutos atrás, ESerra disse:

Esse é o primeiro problema "talvez"... talvez é a mãe de todos os erros, você tem que entender o que está fazendo para só assim corrigir o problema.

 

Está sendo inserido 0000-00-00 porque o formato da data está fora do padrão que o campo exige.

 

Então, ANTES do insert, dê um echo na variável e veja o que de fato está sendo passado para o insert, esse será o ponto de partida.

 

 

Fiz assim: 

 

$data_operacao2 = '02/03/2017';
$data_operacao2 = implode("-", array_reverse(explode("/", $data_operacao2)));
echo $data_operacao2; 

 

 

E retornou assim:  2017-03-02 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
5 minutos atrás, ESerra disse:

Posta o script inteiro.

 

Já achei o que era... era um erro BESTA no input, que estava como "text", mudei para "date" e funcionou. Obrigada à todos! =)

 

 

Mas tenho outra dúvida no mesmo assunto:

 

Tenho uma página de edição que retorna os dados gravados de acordo com o ID,  que agora está retornando a data no formato em que ela foi gravada " 2017-03-02 ".

Como faço para mostrar na tela no formato pt_br e fazer o update no formato do banco novamente? 

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
16 minutos atrás, CamilaDePaula disse:

 

Já achei o que era... era um erro BESTA no input, que estava como "text", mudei para "date" e funcionou. Obrigada à todos! =)

Funcionou "na sorte", pois o simples fato de usar um input text não justifica o erro em si.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por Jonas Ribeiro Nascimento
      Estou criando meu próprio mvc php para adquirir mais conhecimento.
      Mas estou me deparando com uma coisa muita estranha, eu perco a $_SESSION de uma view para outra view
      Fiz um codigo simples pra testar.a.php ----- view a.php
      <?php session_start(); $_SESSION['teste'] = 'Funcionou'; echo $_SESSION['teste']; ?> <?php session_start(); echo $_SESSION['teste']; // Notice: Undefined variable: _SESSION in var_dump($_SESSION); // Notice: Undefined variable: _SESSION in NULL ?> <?php namespace Sis\Classes; use App\Model\ClassLogin; use Sis\Traits\TraitGetIp; class ClassSession { private $login; private $timeSession = 1200; private $timeCanary = 300; public function __construct(){ if(session_id() == ''){ ini_set("session.save_handler", "files"); //Cabeçalhos somente atraves de arquivos ini_set("session.use_cookies", 1); //Habilita o uso de cookies ini_set("session.use_only_cookies", 1); //Só pode habilitar a seção atraves de coockies ini_set("session.cookie_domain", DOMAIN); //Só aceita coockies vindo do nosso sistema ini_set("session.cookie_httponly", 1); //Só aceita script php e não deixa o javascript alterar o sistema if(DOMAIN != "localhost"){ ini_set("session.cookie_secure", 1); //Para trabalhar com o SSL do servidor ativo } /*Criptografia das nossas sessions*/ ini_set("session.entropy_length", 512); // ini_set("session.entropy_file","/dev/urandom"); ini_set("session.hash_function", "sha256"); ini_set("session.hash_bits_per_character", 5); session_start(); } $this->login = new ClassLogin(); } #Proteger contra roubo de sessão public function setSessionCanary($par=null){ session_regenerate_id(true); if($par == null){ $_SESSION['canary']=[ "birth" => time(), "IP" => TraitGetIp::getUserIp() //Pega o ip do usuario ]; }else{ $_SESSION['canary']['birth']=time(); } } #Verificar a integridade da sessão public function verifyIdSessions(){ if(!isset($_SESSION['canary'])){ $this->setSessionCanary(); } if($_SESSION['canary']['IP'] !== TraitGetIp::getUserIp()){ $this->destructSessions(); $this->setSessionCanary(); } if($_SESSION['canary']['birth'] < time() - $this->timeCanary){ $this->setSessionCanary("Time"); } } #Setar as sessões do nosso sistema public function setSessions($Email){ $this->verifyIdSessions(); $_SESSION['Login'] = true; $_SESSION['Time'] = time(); $_SESSION['Nome'] = $this->login->getIssetSession($Email)['data']['Nome']; $_SESSION['Email'] = $this->login->getIssetSession($Email)['data']['Email']; $_SESSION['Permissoes'] = $this->login->getIssetSession($Email)['data']['Permissoes']; } #Validar as páginas internas do sistema public function verifyInsideSession(){ $this->verifyIdSessions(); if(!isset($_SESSION['Login']) || !isset($_SESSION['Permissoes']) || !isset($_SESSION['canary'])){ $this->destructSessions(); header("Location: ".DIRPAGE."NaoAutorizado"); }else{ if($_SESSION['Time'] >= time() - $this->timeSession){ $_SESSION['Time']=time(); }else{ $this->destructSessions(); header("Location: ".DIRPAGE."NaoAutorizado"); } } } #Destruir as sessions existentes public function destructSessions(){ foreach (array_keys($_SESSION) as $key) { unset($_SESSION[$key]); } } #testar public function testarSessions(){ echo 'oiiiiiiiiiiiiiiiiiiiiiiooooooooooo'; } }

    • Por Allan Carlos dos Santos G
      Bom dia Pessoal, Gostaria de saber como Instalar e colocar pra rodar a versão do Zend PHP 1.11.11, tenho tido dificuldade de achar material na internet e se puderem ajudar, obrigado!
    • Por Perroni91
      Olá pessoal.
      Estou com uma dúvida, mas como sou leiga no mysql, não estou conseguindo resolver.
       
      Tenho duas tabelas no meu banco de dados:
       
      Posts
      id
      titulo_principal
      categoria_id
      imagem
       
      Categorias
      id
      categoria
       
      ---

      Já cadastrei as categorias 'HTML' e 'CSS', e cada um contêm 1 post de cada.

      O que eu gostaria era que: A cada vez que criar um post em alguma dessas categorias, mostrar a quantidade separadamente.

      Ficaria assim:
      HTML               3
      CSS                   1


      Alguém poderia me ajudar, por favor?
      Estou quebrando a cabeça tentando fazer isso e não consegui.
      Obrigada!
    • Por Rogerio Pancini
      Bom dia pessoal!

      Estou com seguinte caso: preciso fazer uma coleta de dados, que no caso seria esta seleção:
       
      $sql_c_1 = mysqli_query($config, "SELECT DISTINCT id_malote FROM boletosdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_1) <= '0'){ $c_sql_c_1[] = ""; }else{ while($r_sql_c_1 = mysqli_fetch_array($sql_c_1)){ $c_sql_c_1[] = $r_sql_c_1[0]; } } $sql_c_2 = mysqli_query($config, "SELECT DISTINCT id_malote FROM caixasdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_2) <= '0'){ $c_sql_c_2[] = ""; }else{ while($r_sql_c_2 = mysqli_fetch_array($sql_c_2)){ $c_sql_c_2[] = $r_sql_c_2[0]; } } $sql_c_3 = mysqli_query($config, "SELECT DISTINCT id_malote FROM notasfiscaisdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_3) <= '0'){ $c_sql_c_3[] = ""; }else{ while($r_sql_c_3 = mysqli_fetch_array($sql_c_3)){ $c_sql_c_3[] = $r_sql_c_3[0]; } } $sql_c_4 = mysqli_query($config, "SELECT DISTINCT id_malote FROM documentosdomalote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_4) <= '0'){ $c_sql_c_4[] = ""; }else{ while($r_sql_c_4 = mysqli_fetch_array($sql_c_4)){ $c_sql_c_4[] = $r_sql_c_4[0]; } } $sql_c_5 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_cheque_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_5) <= '0'){ $c_sql_c_5[] = ""; }else{ while($r_sql_c_5 = mysqli_fetch_array($sql_c_5)){ $c_sql_c_5[] = $r_sql_c_5[0]; } } $sql_c_6 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_holerite_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_6) <= '0'){ $c_sql_c_6[] = ""; }else{ while($r_sql_c_6 = mysqli_fetch_array($sql_c_6)){ $c_sql_c_6[] = $r_sql_c_6[0]; } } $sql_c_7 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_material_grafico_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_7) <= '0'){ $c_sql_c_7[] = ""; }else{ while($r_sql_c_7 = mysqli_fetch_array($sql_c_7)){ $c_sql_c_7[] = $r_sql_c_7[0]; } } $sql_c_8 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_outros_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_8) <= '0'){ $c_sql_c_8[] = ""; }else{ while($r_sql_c_8 = mysqli_fetch_array($sql_c_8)){ $c_sql_c_8[] = $r_sql_c_8[0]; } } $sql_c_9 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_dinheiro_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_9) <= '0'){ $c_sql_c_9[] = ""; }else{ while($r_sql_c_9 = mysqli_fetch_array($sql_c_9)){ $c_sql_c_9[] = $r_sql_c_9[0]; } } $sql_c_10 = mysqli_query($config, "SELECT DISTINCT id_malote FROM tb_dep_pessoal_malote WHERE usuario_recebimento = '$id_usuario' AND conffin <> 'S'") or die(mysqli_error($config)); if(@mysqli_num_rows($sql_c_10) <= '0'){ $c_sql_c_10[] = ""; }else{ while($r_sql_c_10 = mysqli_fetch_array($sql_c_10)){ $c_sql_c_10[] = $r_sql_c_10[0]; } }
      Eu até fiz teste com arrays.
      Se eu der um implode, consigo fazer o select que preciso:
       
      if(!empty($c_sql_c_1)){ $v_c_sql_c_1 = implode(",",$c_sql_c_1); }else{ $v_c_sql_c_1 = ""; }
       
      $sql_3 = mysqli_query($config, "SELECT ma.id, ma.titulo, ma.datadecadastro, usr.nome, ma.id_estabelecimento_origem, ma.id_estabelecimento_destino, ma.status, ma.id_usuario_envio FROM malote ma LEFT JOIN usuario AS usr ON (ma.id_usuario_envio = usr.id) WHERE ma.id_estabelecimento_origem = '$id_estabelecimento' && ma.id_usuario_cadastro = '$id_usuario' OR ma.id_estabelecimento_destino = '$id_estabelecimento' && ma.id_usuario_cadastro = '$id_usuario' OR ma.status = '1' && ma.id_estabelecimento_origem = '$id_estabelecimento' OR ma.status = '2' && ma.id_estabelecimento_origem = '$id_estabelecimento' OR ma.status = '1' && ma.id_estabelecimento_destino = '$id_estabelecimento' OR ma.status = '2' && ma.id_estabelecimento_destino = '$id_estabelecimento' OR ma.id IN ($v_c_sql_c_1) ORDER BY ma.datadecadastro DESC") or die(mysqli_error($config)); }
      Porém, eu precisaria fazer o select com todos os resultados acima.

      Fiz outro teste, concatenando todos:
       
      echo $v_c_sql_c_1 . " " . $v_c_sql_c_2 . " " . $v_c_sql_c_3 . " " . $v_c_sql_c_4 . " " . $v_c_sql_c_5 . " " . $v_c_sql_c_6 . " " . $v_c_sql_c_7 . " " . $v_c_sql_c_8 . " " . $v_c_sql_c_9 . " " . $v_c_sql_c_10;
      E o resultado foi esse:

      312,317 312,317,324 312

      Apesar de não estar bonito, se funcionasse poderia ser assim, mas o $sql_3 não lê, por ter espaços sem vírgula, além do resultado estar errado, por ter id's repetidos.

      Se alguém tiver alguma ideia da forma mais correta de chegar ao resultado final, eu agradeço.
      Pensei em formar um array, com o array_merge, mas não deu certo também.
      Enfim, a ideia é juntar todos os resultados, de forma não repetida, para incluir no $sql_3.

      Obrigado pela atenção.
       
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.