Oracle
 sql >> Base de Dados >  >> RDS >> Oracle

Oracle sql classifica os dias da semana pelo dia atual


Se você estiver tentando classificar um conjunto de datas por dia da semana, sendo o sábado o primeiro, considere ordenar por uma data modificada:
create table t1(my_date date);
insert into t1
select trunc(sysdate)+rownum
from dual
connect by level <= 20

select
  my_date,
  to_char(my_date,'Day'),
  to_char(my_date,'D')
from
  t1
order by
  to_char(my_date + 1,'D');

http://sqlfiddle.com/#!4/5940b/3

A desvantagem é que não é muito intuitivo, então adicione um comentário de código se você usar esse método.

Edit:Onde você tem uma lista de números, ordene por uma instrução case com uma conversão de lista:
case day
  when 1 then 3
  when 2 then 4
  when 3 then 5
  when 4 then 6
  when 5 then 7
  when 6 then 1 -- saturday
  when 7 then 2
end

... ou o mais compacto, mas não tão intuitivo:
case
  when day <= 5 then day + 2
  else               day - 5
end

order by case