Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

asacap1000

Ultima data independente do id

Recommended Posts

Galera não sei o porque mas n select abaixo eu preciso mostrar o ultimo registro de uma das datas que são lançadas.

SELECT IO.ID_IN_OUT TICKET,
       TO_CHAR(IO.TIME_ARRIVAL, 'DD/MM/YYYY HH24:MI') CHEGADA,
       TO_CHAR(IO.TIME_RELEASE_IN, 'DD/MM/YYYY HH24:MI') LIBERADO,
       TO_CHAR(IO.TIME_IN, 'DD/MM/YYYY HH24:MI') ENTRADA,
       SUBSTR(SP.NAME, 0, 18) TRANSPORTADORA,
       SUBSTR(DR.NAME, 0, 18) MOTORISTA,
       VE.PLATE PLACA,
       (SELECT DISTINCT MAX(TOS.PLATZ) DOCA
          FROM PICKAUF PI,
               AUFTRAEGE TOS,
               (SELECT IO.ID_IN_OUT,
                       MAX(IO.TIME_RELEASE_PP) TIME_RELEASE_PP,
                       IOP.DOCUMENT,
                       MAX(IO.TIME_OUT) TIME_OUT
                  FROM IN_OUT IO, IN_OUT_POS IOP
                 WHERE IO.ID_IN_OUT = IOP.ID_IN_OUT
                      --AND IO.ART_IN_OUT IN ('CA', 'CCE', 'CC')
                   AND IO.STAT <> '80'
                 GROUP BY IOP.DOCUMENT, IO.ID_IN_OUT) SAD
         WHERE PI.CHARGE = TOS.NR_AUF
           AND SAD.ID_IN_OUT = IO.ID_IN_OUT
           AND SAD.DOCUMENT(+) =
               REPLACE(TRANSLATE(TOS.HINW_ZUST, '/-', '  '), ' ')
         GROUP BY SAD.ID_IN_OUT) DOCA
  FROM IN_OUT IO, SPEDITEURE SP, VEHICLE VE, TRACTOR TR, DRIVER DR
 WHERE IO.STAT <> '80'
   AND IO.TIME_ARRIVAL IS NOT NULL
   AND TR.ID_TRACTOR = IO.ID_TRACTOR
   AND DR.ID_DRIVER = IO.ID_DRIVER
   AND VE.ID_VEHICLE = IO.ID_VEHICLE
	  
   AND IO.TIME_RELEASE_PP IS NULL
   AND SP.ID_SPEDITEUR = IO.ID_SPEDITEUR
   AND IO.ART_IN_OUT IN ('CA', 'CC', 'CCE', 'CV')
   and rownum = '1'
 ORDER BY TO_CHAR(IO.TIME_RELEASE_IN, 'DD/MM/YYYY HH24:MI')

Neste Select temos as datas de CHEGADA, LIBERADO, ENTRADA. eu preciso mostrar o ultimo registro do LIBERADO. Eu já fiz um max porém não retornou.Ela será utilizada em um telão no pátio de uma empresa.

 

O telão será desta forma

 

Capturar.thumb.JPG.e2b79e58f62bec652aef5e76fbd6af9d.JPG

Compartilhar este post


Link para o post
Compartilhar em outros sites

asacap1000

O que ocorre no seu caso é que você utiliza o campo DATA (Liberado) como STRING (TO_CHAR) e quando fazemos uma ordenação ORDER BY a ordem de uma STRING começa da esquerda para a direita, LOGO se eu tenho duas datas 04/12/2019 e 29/01/2019 o menor valor é 04/12/2019 porque o primeiro CHAR é 0 e ZEROS é menor do que o primeiro CHAR da outra data que é 2, então eu recomendo você a converter o campo de DATA no seu ORDEY BY para um campo DATA e então ordenar por DESC que é do MAIOR valor para o MENOR valor caso você queira limitar a 1 registro adiciona LIMIT 1.

 

Se o seu campo "IO.TIME_RELEASE_IN" for um campo do FORMATO DATE ou DATETIME na sua estrutura da tabela, você só precisa remover o "TO_CHAR(IO.TIME_RELEASE_IN, 'DD/MM/YYYY HH24:MI')" e deixar apenas IO.TIME_RELEASE_IN DESC caso ele seja um VARCHAR recomendo você a utilizar um dos dois comandos abaixo:

 

Trocar TO_CHAR o para DATE_FORMAT como exemplo abaixo:

SELECT * FROM sua_tabela ORDER BY DATE_FORMAT(data_cadastro,'%d/%m/%Y')

Ou trocar TO_CHAR o para STR_TO_DATE como exemplo abaixo:

SELECT * FROM sua_tabela ORDER BY STR_TO_DATE( dt_registro_valor,  '%d/%m/%Y' )
SELECT IO.ID_IN_OUT TICKET,
       TO_CHAR(IO.TIME_ARRIVAL, 'DD/MM/YYYY HH24:MI') CHEGADA,
       TO_CHAR(IO.TIME_RELEASE_IN, 'DD/MM/YYYY HH24:MI') LIBERADO,
       TO_CHAR(IO.TIME_IN, 'DD/MM/YYYY HH24:MI') ENTRADA,
       SUBSTR(SP.NAME, 0, 18) TRANSPORTADORA,
       SUBSTR(DR.NAME, 0, 18) MOTORISTA,
       VE.PLATE PLACA,
       (SELECT DISTINCT MAX(TOS.PLATZ) DOCA
          FROM PICKAUF PI,
               AUFTRAEGE TOS,
               (SELECT IO.ID_IN_OUT,
                       MAX(IO.TIME_RELEASE_PP) TIME_RELEASE_PP,
                       IOP.DOCUMENT,
                       MAX(IO.TIME_OUT) TIME_OUT
                  FROM IN_OUT IO, IN_OUT_POS IOP
                 WHERE IO.ID_IN_OUT = IOP.ID_IN_OUT
                      --AND IO.ART_IN_OUT IN ('CA', 'CCE', 'CC')
                   AND IO.STAT <> '80'
                 GROUP BY IOP.DOCUMENT, IO.ID_IN_OUT) SAD
         WHERE PI.CHARGE = TOS.NR_AUF
           AND SAD.ID_IN_OUT = IO.ID_IN_OUT
           AND SAD.DOCUMENT(+) =
               REPLACE(TRANSLATE(TOS.HINW_ZUST, '/-', '  '), ' ')
         GROUP BY SAD.ID_IN_OUT) DOCA
  FROM IN_OUT IO, SPEDITEURE SP, VEHICLE VE, TRACTOR TR, DRIVER DR
 WHERE IO.STAT <> '80'
   AND IO.TIME_ARRIVAL IS NOT NULL
   AND TR.ID_TRACTOR = IO.ID_TRACTOR
   AND DR.ID_DRIVER = IO.ID_DRIVER
   AND VE.ID_VEHICLE = IO.ID_VEHICLE
	  
   AND IO.TIME_RELEASE_PP IS NULL
   AND SP.ID_SPEDITEUR = IO.ID_SPEDITEUR
   AND IO.ART_IN_OUT IN ('CA', 'CC', 'CCE', 'CV')
   and rownum = '1'
 ORDER BY TO_CHAR(IO.TIME_RELEASE_IN, 'DD/MM/YYYY HH24:MI')
 ORDER BY DATE_FORMAT(IO.TIME_RELEASE_IN, '%d/%m/%Y %H/$i') DESC
--OU
 ORDER BY STR_TO_DATE(IO.TIME_RELEASE_IN, '%c/%e/%Y %r') DESC
--OU
 ORDER BY STR_TO_DATE(IO.TIME_RELEASE_IN, '%d/%m/%Y %H/$i') DESC

 

O seu erro esta aparentemente no TO_CHAR.

Explicação na prática com exemplo no site:

--> Viva O Linux - Convertendo Varchar em Date no MySQL para Ordenação.

 

Se a minha resposta for útil não esqueça de agradecer e votar positivo.

Espero ter ajudado de alguma forma.

 

Att
Felipe Guedes Coutinho

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      Fala pessoal.
      Tudo bem?
       
      Tenho o seguinte código que funcionda perfeitamente:
       
      date_default_timezone_set("America/Sao_Paulo");
      $d_inicio= date('Y-m-d');
      $d_final= date('Y-m-d', strtotime('+30  day'));
       
      Mas eu quero definir a quantidade de dias pegando o valor que a variável:
       
      date_default_timezone_set("America/Sao_Paulo");
      $tempo = 30;
      $d_inicio= date('Y-m-d');
      $d_final= date('Y-m-d', strtotime('+$tempo  day'));
       
      Mas quando declaro com variável não funciona.
      Obrigado pela ajuda.
    • Por ILR master
      Fala galera, tudo bem?
       
      Tenho o seguinte codigo:
       
       class Data {
      public static function ExibirTempoDecorrido($date)
      {
          if(empty($date))
          {
              return "Informe a data";
          }
          $periodos = array("segundo", "minuto", "hora", "dia", "semana", "mês", "ano", "década");
          $duracao = array("60","60","24","7","4.35","12","10");
          $agora = time();
          $unix_data = strtotime($date);
          // check validity of date
          if(empty($unix_data))
          {  
              return "Bad date";
          }
          // is it future date or past date
          if($agora > $unix_data) 
          {  
              $diferenca     = $agora - $unix_data;
              $tempo         = "atrás";
          } 
          else 
          {
              $diferenca     = $unix_data - $agora;
              $tempo         = "agora";
          }
          for($j = 0; $diferenca >= $duracao[$j] && $j < count($duracao)-1; $j++) 
          {
              $diferenca /= $duracao[$j];
          }
          $diferenca = round($diferenca);
          if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
          return "$diferenca $periodos[$j] {$tempo}";
      }
      }
       
      Funciona redondinho se o valor retornado for de algumas horas, mas...
      Quando passa de dois meses, ele retorna a palavra mess. Deve ser por conta dessa linha
      if($diferenca != 1) 
          {
              $periodos[$j].= "s";
          }
       
      Quero que modre:
       
      2 meses atrás
      e não
      2 mess atrás.
       
      Espero que tenham entendido.
       
      Valeu
    • Por FabianoSouza
      Eu preciso exibir duas informações em minha consulta:
      1) A quantidade de pessoas inscritas numa turma de treinamento (isso é feito com um simples COUNT)
      2) Uma flag de excesso de inscrições na turma. Seria obtido pela comparação entre a quantidade máxima permitida (já existe esse campo) e o COUNT feito acima.
       
      Até aqui sem problemas.
       
      O que quero é evitar fazer duas contagens (1 para saber a quantidade de inscritos, e outra para gerar a flag de excesso de inscrições).
       
      Há uma forma de utilizar UMA contagem para atender as duas necessidades?
       
      Meu código está assim:
       
      ... --AQUI FAZ A COMPARAÇÃO PARA GERAR A FLAG DE EXCESSO DE INSCRIÇÕES , CASE WHEN (SELECT COUNT(*) FROM dbo.tab AS ITT WHERE ITT.codTurmaDeTreina = T.id) > T.lotacaoMax Then T.nome + '&nbsp;'+'<span class=%22icon-aviso fcolor-critico%22 style=%22font-size:18px%22 title=Excesso&nbsp;de&nbsp;inscrições></span>' --AQUI FAZ A CONTAGEM DE INSCRIÇÕES , (SELECT COUNT(*) FROM dbo.tab AS ITT WHERE ITT.codTurmaDeTreina = T.id) AS 'Inscrições'  
    • Por FabianoSouza
      Possuo uma coluna de data.
      Eu gostaria que os registros com datas futuras aparecessem no topo do meu select, em relação aos demais registros.
      Em seguida, gostaria que somente esses registros com datas futuras ficassem em ordem crescente.
      Algo como 
       
      João  | 16/11/2023
      Maria | 17/11/2023
      José  |  20/11/2023
       
      -----------------------------
      (demais registros da base)
      Antônio   |  20/05/2023
      Rosa        | 15/08/2023
      Cida         | 15/10/2022
      Pedro      |  20/05/2021
      Paulo      |  14/11/2020
       
      O select seria esse.
      select dbo.formataData(ET.dataInicial) AS 'data' FROM dbo.tab AS ET GROUP BY ET.dataInicial  
    • Por mateus.andriollo
      Existe uma forma de fazer um IF na select e comparar com Array de dados?
       
      algo como
       
      Select if( in_array(idCliente,'1,2,3,4,5')=true,'Tem','Não') ) as cliente Não consigo usar inner ou where pois esse array é algo q tem varias regras...
       
      Precisava saber se existe uma função assim em MySQL
×

Informação importante

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