У меня возникают проблемы с сортировкой столбца чисел и слов в определенном порядке возрастания типа nvarchar
.
когда я запускаю этот запрос
select GradedDescriptions from cards order by GradedDescriptions asc
я получил
10
5
8
8.5
Authentic
Authentic
Black 10
Но мой желаемый результат
Authentic
5
8
8.5
10
Black 10
Есть ли способ поставить Authentic перед цифрами и Black 10 в конце?
Нет черных 8, есть только черные 10. Порядок Аутентичный, 1, 1,5, 2, 2,5... 10, черный 10
Действительно ли в ваших данных есть 2 экземпляра Authentic
? Являются ли значения DISTINCT частью желаемого результата?
Нет, не может быть N сумм. Но я бы хотел, чтобы Authentic был перед цифрами, а черная 10 — после цифр.
Возможно, что-то вроде этого
Declare @YourTable Table ([GradedDescriptions] varchar(50))
Insert Into @YourTable Values
('10')
,('5')
,('8')
,('8.5')
,('Authentic')
,('Black 10')
Select * from @YourTable
Order by try_convert(money,right([GradedDescriptions],3))
,[GradedDescriptions]
Полученные результаты
GradedDescriptions
Authentic
5
8
8.5
10
Black 10
@Train Всегда рад помочь.
money
правда? sqlblog.org/2021/03/09/мои-два-наименее-любимые-типы-данных Что не так с decimal
@Charlieface Да, деньги, они, как правило, немного более снисходительны к преобразованиям и меньшему количеству нажатий клавиш, чем decimal(#,#) .
А если черные 8... будет ли это между 8 и 8,5?