Это работает для меня:
order by
case when :dir_param = 'ASC' then
case :col_param
when 'col_1_identifier' then col_1_name
when 'col_2_identifier' then col_2_name
...
end
end,
case when :dir_param = 'DSC' then
case :col_param
when 'col_1_identifier' then col_1_name
when 'col_2_identifier' then col_2_name
...
end
end desc
или
order by
case when :dir_param = 'ASC' and :col_param = 'col_1_identifier' then col_1_name end,
case when :dir_param = 'DSC' and :col_param = 'col_1_identifier' then col_1_name end desc,
case when :dir_param = 'ASC' and :col_param = 'col_2_identifier' then col_2_name end,
case when :dir_param = 'DSC' and :col_param = 'col_2_identifier' then col_2_name end desc
заменить литералы, имена переменных и столбцов теми, которые соответствуют вашей ситуации.Oracle, похоже, очень требователен к размещению спецификатора направления сортировки desc.