Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Запрос и Case When Else End внутри / 2 сообщений из 2, страница 1 из 1
13.05.2019, 23:17
    #39812701
Qwe.Qwe1
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Запрос и Case When Else End внутри
Пытаюсь выбрать по определенным правилам строки, но почему-то внутренний Case выдает пустые значения, если строки не содержат подчеркивания. Не пойму почему?
(данные для примера) - надо выбрать такие строки:
- если есть "/", то знаменатель;
- если есть "_", то слово до подчеркивания;
- в остальных случаях - просто выбрать эту строку.
Что не так?

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
Declare @MyData Table (MyName varchar(50))
Insert Into @MyData (MyName) Values('Миша')
Insert Into @MyData (MyName) Values('Вася_1')
Insert Into @MyData (MyName) Values('Вася_25')
Insert Into @MyData (MyName) Values('Даша')
Insert Into @MyData (MyName) Values('Вася')
Insert Into @MyData (MyName) Values('Клава/Ира')

Select Substring(Case When MyName Like '%_%' Then Substring(MyName, 0, CharIndex('_', MyName, 0)) Else MyName End, CharIndex('/', MyName, 0) + 1, Len(MyName)) From @MyData
...
Рейтинг: 0 / 0
13.05.2019, 23:56
    #39812709
felix_ff
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Запрос и Case When Else End внутри
Qwe.Qwe1,

потому что like работает c wildcard, читайте справку
Код: sql
1.
Select Substring(Case When MyName Like '%[_]%' Then Substring(MyName, 0, CharIndex('_', MyName, 0)) Else MyName End, CharIndex('/', MyName, 0) + 1, Len(MyName)) From @MyData
...
Рейтинг: 0 / 0
Форумы / Microsoft SQL Server [игнор отключен] [закрыт для гостей] / Запрос и Case When Else End внутри / 2 сообщений из 2, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]