Есть ли StartsWith или содержит в t sql переменные?
Я пытаюсь определить, работает ли на сервере Express Edition.
У меня есть следующий t sql.
DECLARE @edition varchar(50);
set @edition = cast((select SERVERPROPERTY ('edition')) as varchar)
print @edition
В моем случае @edition = Express Edition (64-bit)
Как я могу сделать следующее? (Вдохновлен С#).
DECLARE @isExpress bit;
set @isExpress = @edition.StartsWith('Express Edition');
Ответы
Ответ 1
StartsWith
: left(@edition, 15) = 'Express Edition'
или charindex('Express Edition', @edition) = 1
.
Contains
: charindex('Express Edition', @edition) >= 1
<сильные > Примеры:
Использование left
:
set @isExpress = case when left(@edition, 15) = 'Express Edition' then 1 else 0 end
или начиная с SQL Server 2012 вы можете использовать iif
:
set @isExpress = iif(left(@edition, 15) = 'Express Edition', 1, 0);
или используя charindex
:
set @isExpress = iif(charindex('Express Edition', @edition) = 1, 1, 0);
Ответ 2
Кажется, что вы хотите http://msdn.microsoft.com/en-us/library/ms186323.aspx.
В вашем примере это будет (начинается с):
set @isExpress = (CharIndex('Express Edition', @edition) = 1)
Или содержит
set @isExpress = (CharIndex('Express Edition', @edition) >= 1)
Ответ 3
Я бы использовал
like 'Express Edition%'
Пример:
DECLARE @edition varchar(50);
set @edition = cast((select SERVERPROPERTY ('edition')) as varchar)
DECLARE @isExpress bit
if @edition like 'Express Edition%'
set @isExpress = 1;
else
set @isExpress = 0;
print @isExpress