Postgres giver dig mulighed for at sortere efter arrays -- hvilket i bund og grund er hvad versionsnummeret repræsenterer. Derfor kan du bruge denne syntaks:
order by string_to_array(version, '.')::int[] desc
Her er et fuldstændigt eksempel:
select *
from (values ('1'), ('2.1'), ('1.2.3'), ('1.10.6'), ('1.9.4')) v(version)
order by string_to_array(version, '.')::int[] desc;
Og endda en demonstration .