Ir para conteúdo
Fórum Script Brasil
  • 0

Problemas com data MYSQL


KCK net

Pergunta

Tenho que fazer uma consulta no banco mysql mas estou com um problema na minha query.

No meu banco tenho 3 campos string, sendo um day, month e year. Estes não são datas, e sim varchar. Ok. Não poderei mudar isso pois peguei este banco assim mesmo. Quero pegar as datas iguais ou maiores do que hoje. Ele me retorna até virar maio, mas dai pega acima do dia 26-05 e não antes. Existe alguma forma ou função de melhorar isso? Qualquer ajuda será bem-vinda. Atenciosamente

SELECT *,(str_to_date(CONCAT(agenda.year,'-',agenda.month,'-',agenda.day), '%Y-%m-%d')) as dta 
FROM agenda 
WHERE  agenda.day >= 26 
AND  agenda.month >= 04 
AND  agenda.year >= 2016 
ORDER BY  (str_to_date(CONCAT(agenda.year,'-',agenda.month,'-',agenda.day), '%Y-%m-%d'))  
LIMIT 6

 

Link para o comentário
Compartilhar em outros sites

1 resposta a esta questão

Posts Recomendados

  • 0

Boa tarde.

Você pode usar subselect... assim:

SELECT
		*, dta
	FROM (
		SELECT *, STR_TO_DATE(CONCAT(agenda.year, '-', agenda.month, '-', agenda.day), '%Y-%m-%d') AS dta FROM agenda
	) AS dados_agenda
	WHERE dta >= CURRENT_DATE /*'2016-04-26'*/
	ORDER BY dta
	LIMIT 6

 

Link para o comentário
Compartilhar em outros sites

Participe da discussão

Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.

Visitante
Responder esta pergunta...

×   Você colou conteúdo com formatação.   Remover formatação

  Apenas 75 emoticons são permitidos.

×   Seu link foi incorporado automaticamente.   Exibir como um link em vez disso

×   Seu conteúdo anterior foi restaurado.   Limpar Editor

×   Você não pode colar imagens diretamente. Carregar ou inserir imagens do URL.



  • Estatísticas dos Fóruns

    • Tópicos
      152,3k
    • Posts
      652,4k
×
×
  • Criar Novo...