Skip Navigation Links
Novas Tecnologias
Ferramentas Adicionais
Ferramentas Adicionais


Dica No :
376
Assunto : SQL Server
Titulo: Cuidado com o Order by em datas

Gostou do texto ? Vote e dê sua opinião! Pontuação atual :

Translate this page now :






Adicione aos Favoritos!
BlogBlogs Rec6 Linkk Ueba Technorati Delicious DiggIt! StumbleUpon



Não é raro que ao recuperar datas do banco de dados, especialmente para web, a recuperação seja feita em um formato já pronto para a exibição. Para tanto utiliza-se a instrução CONVERT para realizar a recuperação.

Vamos ver um exemplo :

select convert(Varchar,data,103) as data from tabela

Agora vamos tentar fazer uma ordenação do resultado :

select convert(Varchar,data,103) as data from tabela order by data

Talvez você não note de imediato, mas o order by irá falhar. Isso porque o order by é uma clausula capaz de reconhecer alias de campos. Ele é uma das últimas clausulas a serem processadas, por isso quando o order by é processado isso já acontece sobre a informação convertida para varchar, e o order by em varchar será bem diferente do order by em uma data.

No exemplo de select acima não temos como fazer o order by pela data propriamente. Vamos mudar um pouco o exemplo :

select convert(Varchar,data,103) as dt from tabela order by data

Com o alias diferente do nome do campo o order by reconhece que deve ser feita a ordenação pelo campo e, enfim, temos o resultado esperado.


Nome :
E-mail:
Comentarios :
 
 
Os Últimos Comentários
Nenhum comentário foi realizado ainda. Seja o primeiro !
Dicas
Dica do Dia
Receba Dicas Por Email
E-mail :  
 


 (help)
Aceito receber informativos do devASPNet, informações de eventos e treinamentos

Veja Quais Informativos Você Receberá

Pesquisar Dicas
Pesquisar Artigos, Dicas e Noticias

Banco de Dados
Algumas Entrevistas
Links Importantes

Búfalo Informática, Treinamento e Consultoria
R. Alvaro Alvim, 37/920 Centro - Cinelândia - Rio de Janeiro Cep: 20031-010
Tel : (21) 2262-1368 (21) 9240-5134 E-mail : Contato@bufaloinfo.com.br