Jeśli dobrze rozumiem, możesz użyć union all
aby obliczyć sumę dla każdej kolumny, a następnie order by
i limit
:
select c.*
from ((select 'col1', sum(col1) as s from t) union all
(select 'col2', sum(col2) as s from t) union all
. . .
(select 'col10', sum(col10) as s from t)
) c
order by s desc
limit 3;