Есть ли 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)
как я могу сделать следующее? (C # inspired).
DECLARE @isExpress bit;
set @isExpress = @edition.StartsWith('Express Edition');
3 ответа:
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);
похоже, что вы хотите http://msdn.microsoft.com/en-us/library/ms186323.aspx.
в вашем примере это будет (начинается с):
set @isExpress = (CharIndex('Express Edition', @edition) = 1)или содержит
set @isExpress = (CharIndex('Express Edition', @edition) >= 1)