Jump to content
adriano.eurich

Mascaras e conversão de data PHP mySql

Recommended Posts

Estou tendo dificuldade para entender como é feito o tratamento de mascaras e conversões de data, tenho a pagina cadastro.php onde tem os campos para digitar os dados um deles é a data de nascimento, onde coloquei as mascaras na pagina de script como mostra em anexo, dessa forma ele mostra certo os campos para o cliente digitar no formato 00/00/0000, porem quando envia ao banco ele aparece como mostra em anexo 0000-00-00, e na pagina consulta ele retorna o valor do banco dessa forma também. Gostaria que aparece a mascara na pagina consulta para o cliente digitar da forma certa 00/00/000 e enviasse ao bando sem as mascara se possível, mas que retornasse a pagina de consulta com as mascara certa no formato 00/00/000 

Obs. Sei que o banco aceita apenas 2019-04-25, qualquer valor inserido em outro formato ele vai entender como 0000-00-00, mas como faria para aparecer na pagina de cadastro.php a mascara 25/04/2019 fosse passado para o banco 2019-04-25 e retorna na consulta.php 25/04/2019.

 

Cadastro de Cliente

 

Pagina Cadastro de Cliente.php

<!-- Campo Data Nasc -->
<div class="input-field col s12">
   <i class="material-icons prefix">event_note</i>
   <input type="text" name="datanasc" id="datanasc" maxlength="10" required>
   <label for="datanasc"> DataNasc do Cliente</label>
</div>

--------------------------------------------------------------------------

Pagina create.php

<?php
session_start();
include_once 'conexao.php';

$nome       = filter_input(INPUT_POST, 'nome', FILTER_SANITIZE_SPECIAL_CHARS);
$email      = filter_input(INPUT_POST, 'email', FILTER_VALIDATE_EMAIL);
$telefone   = filter_input(INPUT_POST, 'telefone', FILTER_SANITIZE_NUMBER_INT);
$cpf        = filter_input(INPUT_POST, 'cpf', FILTER_SANITIZE_NUMBER_INT);
$datanasc   = filter_input(INPUT_POST, 'datanasc', FILTER_VALIDATE_INT);

$querySelect = $link->query("select email from tb_clientes");
$array_emails = [];

while ($emails = $querySelect->fetch_assoc()):
    $emails_existentes = $emails['email'];
    array_push($array_emails, $emails_existentes);
endwhile;

if(in_array($email,$array_emails)):
    $_SESSION['msg'] = "<p class='center red-text'>".'Já existe um cliente cadastrado com esse email'."</p>";
    header("Location: ../CadCli.php");
else:
    $queryInsert = $link->query("insert into tb_clientes values(default,'$nome','$email','$telefone','$cpf','$datanasc')");
    $affected_rows = mysqli_affected_rows($link);
    
    if($affected_rows > 0):
        $_SESSION['msg'] = "<p class='center green-text'>".'Cadastro efetuado com Sucesso!'."<br>";
        header("Location: ../CadCli.php");
    endif;
endif;
-----------------------------------------------------------------------------------------------------
  

Pagina read.php

<?php

include_once 'conexao.php';

$querySelect  = $link->query("select * from tb_clientes");
while ($registros = $querySelect->fetch_assoc()):
    $id       = $registros['id'];
    $nome     = $registros['nome'];
    $email    = $registros['email'];
    $telefone = $registros['telefone'];
    $cpf      = $registros['cpf'];
    $datanasc = $registros['datanasc'];
    
    
    
    echo "<tr>";
    echo "<td>$nome</td><td>$email</td><td>$telefone</td><td>$cpf</td><td>$datanasc</td>";
    echo "<td><a href='editar.php?id=$id'><i class='material-icons'>edit</i></a></td>";
    echo "<td><a href='banco_de_dados/delCliConfirma.php?id=$id'><i class='material-icons'>delete</i></a></td>";
    echo "</tr>";
    
endwhile;
---------------------------------------------------------------------------------------------------------------------
Pagina de Script Jquery

<!-- Inicialização Jquery Mascaras -->
        <script type="text/javascript"> 
            jQuery.noConflict();
            jQuery(function($){
               $("#datanasc").mask("99/99/9999");
               $("#telefone").mask("(099)-99999-9999");
               $("#cpf").mask("999 999 999-99"); 
            });
        </script> 

 

Capturar.PNG

Share this post


Link to post
Share on other sites

Olá Adriano, saudações...

 

Você pode fazer a Máscara para data e hora da seguinte forma:

 

Para Campos Separados - Data e Hora

    $dtafim = date(('d/m/Y'), strtotime($r->datafim));
    $hrsfim = date(('H:i:s'), strtotime($r->horafim)); 

 

ou 

 

Para Campos DateTime

    $dtaHrs = date(('d/m/Y - H:i:s'), strtotime($r->dataHora));

 

 

Espero ter ajudado,

 

Cesar

Share this post


Link to post
Share on other sites
11 horas atrás, violin101 disse:

Olá Adriano, saudações...

 

Você pode fazer a Máscara para data e hora da seguinte forma:

 

Para Campos Separados - Data e Hora

    $dtafim = date(('d/m/Y'), strtotime($r->datafim));
    $hrsfim = date(('H:i:s'), strtotime($r->horafim)); 

 

ou 

 

Para Campos DateTime

    $dtaHrs = date(('d/m/Y - H:i:s'), strtotime($r->dataHora));

 

 

Espero ter ajudado,

 

Cesar

11 horas atrás, violin101 disse:

Olá Adriano, saudações...

 

Você pode fazer a Máscara para data e hora da seguinte forma:

 

Para Campos Separados - Data e Hora

    $dtafim = date(('d/m/Y'), strtotime($r->datafim));
    $hrsfim = date(('H:i:s'), strtotime($r->horafim)); 

 

ou 

 

Para Campos DateTime

    $dtaHrs = date(('d/m/Y - H:i:s'), strtotime($r->dataHora));

 

 

Espero ter ajudado,

 

Cesar

Em 25/04/2019 at 11:39, adriano.eurich disse:

Estou tendo dificuldade para entender como é feito o tratamento de mascaras e conversões de data, tenho a pagina cadastro.php onde tem os campos para digitar os dados um deles é a data de nascimento, onde coloquei as mascaras na pagina de script como mostra em anexo, dessa forma ele mostra certo os campos para o cliente digitar no formato 00/00/0000, porem quando envia ao banco ele aparece como mostra em anexo 0000-00-00, e na pagina consulta ele retorna o valor do banco dessa forma também. Gostaria que aparece a mascara na pagina consulta para o cliente digitar da forma certa 00/00/000 e enviasse ao bando sem as mascara se possível, mas que retornasse a pagina de consulta com as mascara certa no formato 00/00/000 

 

Cadastro de Cliente

 


Pagina Cadastro de Cliente.php

<!-- Campo Data Nasc -->
<div class="input-field col s12">
   <i class="material-icons prefix">event_note</i>
   <input type="text" name="datanasc" id="datanasc" maxlength="10" required>
   <label for="datanasc"> DataNasc do Cliente</label>
</div>

--------------------------------------------------------------------------

Pagina create.php

<?php
session_start();
include_once 'conexao.php';

$nome       = filter_input(INPUT_POST, 'nome', FILTER_SANITIZE_SPECIAL_CHARS);
$email      = filter_input(INPUT_POST, 'email', FILTER_VALIDATE_EMAIL);
$telefone   = filter_input(INPUT_POST, 'telefone', FILTER_SANITIZE_NUMBER_INT);
$cpf        = filter_input(INPUT_POST, 'cpf', FILTER_SANITIZE_NUMBER_INT);
$datanasc   = filter_input(INPUT_POST, 'datanasc', FILTER_VALIDATE_INT);

$querySelect = $link->query("select email from tb_clientes");
$array_emails = [];

while ($emails = $querySelect->fetch_assoc()):
    $emails_existentes = $emails['email'];
    array_push($array_emails, $emails_existentes);
endwhile;

if(in_array($email,$array_emails)):
    $_SESSION['msg'] = "<p class='center red-text'>".'Já existe um cliente cadastrado com esse email'."</p>";
    header("Location: ../CadCli.php");
else:
    $queryInsert = $link->query("insert into tb_clientes values(default,'$nome','$email','$telefone','$cpf','$datanasc')");
    $affected_rows = mysqli_affected_rows($link);
    
    if($affected_rows > 0):
        $_SESSION['msg'] = "<p class='center green-text'>".'Cadastro efetuado com Sucesso!'."<br>";
        header("Location: ../CadCli.php");
    endif;
endif;
-----------------------------------------------------------------------------------------------------
  

Pagina read.php

<?php

include_once 'conexao.php';

$querySelect  = $link->query("select * from tb_clientes");
while ($registros = $querySelect->fetch_assoc()):
    $id       = $registros['id'];
    $nome     = $registros['nome'];
    $email    = $registros['email'];
    $telefone = $registros['telefone'];
    $cpf      = $registros['cpf'];
    $datanasc = $registros['datanasc'];
    
    
    
    echo "<tr>";
    echo "<td>$nome</td><td>$email</td><td>$telefone</td><td>$cpf</td><td>$datanasc</td>";
    echo "<td><a href='editar.php?id=$id'><i class='material-icons'>edit</i></a></td>";
    echo "<td><a href='banco_de_dados/delCliConfirma.php?id=$id'><i class='material-icons'>delete</i></a></td>";
    echo "</tr>";
    
endwhile;
---------------------------------------------------------------------------------------------------------------------
Pagina de Script Jquery

<!-- Inicialização Jquery Mascaras -->
        <script type="text/javascript"> 
            jQuery.noConflict();
            jQuery(function($){
               $("#datanasc").mask("99/99/9999");
               $("#telefone").mask("(099)-99999-9999");
               $("#cpf").mask("999 999 999-99"); 
            });
        </script> 

 

Capturar.PNG

 

Share this post


Link to post
Share on other sites

Olá violin101, obrigado pelo retorno, então eu estou meio confuso, essa dica que você me passou seria para usar no lugar do Jquery como eu fiz ali?

 

Por que eu precisava que na pagina aparecesse para a pessoa digitar no formato 00/00/000, usei aquela jquery e ficou dessa forma, mas quando clica pra enviar para o banco ele passa tudo zerado 0000-00-00, acho que tenho que mudar algo na pagina create.php que receba a data com mascara 00/00/000 e converta para 0000-00-00 antes de enviar para o banco ai o outro problema seria quando eu entrasse na pagina consulta.php ela teria que me mostrar a data no formato 00/00/0000.

 

Edited by adriano.eurich
Faltou uma código

Share this post


Link to post
Share on other sites

Olá Adriano, saudações...

 

Você pode utilizar desta forma:

 

while ($registros = $querySelect->fetch_assoc()):  

 

$dtafim = date(('d/m/Y'), strtotime($registros['datanasc']));

 

$id = $registros['id']; $nome = $registros['nome'];

$email = $registros['email'];

$telefone = $registros['telefone'];

$cpf = $registros['cpf'];

 

 

echo "<tr>";

    echo "<td>$nome</td><td>$email</td><td>$telefone</td><td>$cpf</td><td>$dtafim</td>";

    echo "<td><a href='editar.php?id=$id'><i class='material-icons'>edit</i></a></td>";

   echo "<td><a href='banco_de_dados/delCliConfirma.php?id=$id'><i class='material-icons'>delete</i></a></td>";

echo "</tr>";

 

endwhile;

 

 

Espero ter ajudado

 

 

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By will_chido
      Bom dia a todos sou novo aqui encontrei um problema ao tentar realizar uma consulta em duas tabelas bd, para voltar resultado impresso na tela, ja tentei algumas formas li alguns tópicos mas sem sucesso tentei o uso de inner join talvez ou quase certo eu esteja fazendo errado se alguem puder me ajudar segue o pedaço do meu codigo, preciso incluir a pesquisa tambem na tabela ( categorias)
       
       <?php
                                  foreach ($vendas as $c) {
                                      echo '<tr>';
                                      echo '<td>' . $c->nomeCliente . '</td>';
                                      echo '<td>' . $c->valorTotal. '</td>';
                                      echo '<td>' . date('d/m/Y', strtotime($c->dataVenda)) . '</td>';
                                      echo '<td>' . $c->nome. '</td>';
                                      echo '</tr>';
                                  }
                                  ?>
    • By luigiferrari
      Boa noite, estou precisando de uma ajuda...
       
      Peguei um scrip de calendário e estou listando os dados em uma janela modal:

      O que eu gostaria de fazer é: colocar um botão para direcionar para um link onde o usuário poderá editar.
       
      Eu estou tentando várias vezes, já consegui que o botão aparecesse, porém ou aparece vários botões juntos(com todos os id cadastrados) ou aparece assim:

       
       
      Aqui estão os seguintes códigos:
       
       
      <script> $(document).ready(function() { $('#calendar').fullCalendar({ header: { left: 'prev,next today', center: 'title', right: 'month,agendaWeek,agendaDay' }, defaultDate: Date(), navLinks: true, // can click day/week names to navigate views editable: true, eventLimit: true, // allow "more" link when too many events eventClick: function(event) { $('#visualizar #id').text(event.id); $('#visualizar #title').text(event.title); $('#visualizar #start').text(event.start.format('DD/MM/YYYY')); $('#visualizar #Horario_saida').text(event.Horario_saida); $('#visualizar #Horario_retorno').text(event.Horario_retorno); $('#visualizar #Nome').text(event.Nome); $('#visualizar #Motorista').text(event.Motorista); $('#visualizar').modal('show'); return false; }, events: [ <?php while($row_events = mysqli_fetch_array($resultado_events)){ ?> { id: '<?php echo $row_events['id']; ?>', title: '<?php echo $row_events['title']; ?>', start: '<?php echo $row_events['start']; ?>', Horario_saida: '<?php echo $row_events['Horario_saida']; ?>', Horario_retorno: '<?php echo $row_events['Horario_retorno']; ?>', Nome: '<?php echo $row_events['Nome']; ?>', Motorista: '<?php echo $row_events['Motorista']; ?>', },<?php } ?> ] }); }); </script> <div class="row"> <div class="col-md-6"> <div class="panel panel-primary"> <div class="panel-heading"> <h3 class="panel-title painel-title-responsive">Calendário</h3> </div> <div class="panel-body"> <div id='calendar'></div> <div class="modal fade" id="visualizar" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" data-backdrop="static"> <div class="modal-dialog" role="document"> <div class="modal-content"> <div class="modal-header"> <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button> <h4 class="modal-title text-center">Dados do Evento</h4> </div> <div class="modal-body"> <dl class="dl-horizontal"> <dt>Id:</dt> <dd id="id"></dd> <dt>Nome:</dt> <dd id="Nome"></dd> <dt>Local:</dt> <dd id="title"></dd> <dt>Data:</dt> <dd id="start"></dd> <dt>Saida:</dt> <dd id="Horario_saida"></dd> <dt>Retorno:</dt> <dd id="Horario_retorno"></dd> <dt>Motorista:</dt> <dd id="Motorista"></dd> <div class="col-md-7"></div> <div class="col-md-5"> </dl> <a href="entrar.php?="id='id'">a</a> </div> </div> </div> </div> </div> O erro está na parte do "entrar.php="id='id'", mas não consigo fazer com que apareça apenas um botão com o id correto. Pensei em criar uma variável ou algo assim mas não deu muito certo.
      Poderiam me ajudar?
      Agradeço desde já!!!
    • By Marcosvn
      Estou trabalhando em um projeto de sites para escritores. Nesse projeto existem 12 gêneros dentro da tabela "categorias", por exemplo: Poemas, Acrósticos, Crônicas, etc.
       
      Estou com problemas para criar as rotas para os gêneros corretamente. Vamos supor que um usuário publique um texto do gênero Acrósticos com título: Flores do campo.
       
      A URL está sendo gerada assim: site.com/Acrósticos/flores-do-campo/
       
      Mas eu nao quero que as categorias venham com letra maiscula e acentos na url, fora em outras partes do site. Sendo assim, qual melhor método pra resolver essa situação ?
       
      Criar 12 rotas para cada categoria e puxar apenas o slug do titulo dinamicamente ? ou remover os acentos e letras maisculas na hora de gerar a URL ?
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.