Есть ли StartsWith или содержится в t sql с переменными? - PullRequest
77 голосов
/ 29 февраля 2012

Я пытаюсь определить, работает ли на сервере Express Edition.

У меня есть следующий t sql.

DECLARE @edition varchar(50); 
set @edition = cast((select SERVERPROPERTY ('edition')) as varchar)

print @edition

В моем случае, @edition = Express Edition (64-bit)

Как я могу сделать следующее? (Вдохновленный C #).

DECLARE @isExpress bit;
set @isExpress = @edition.StartsWith('Express Edition');

Ответы [ 3 ]

95 голосов
/ 29 февраля 2012

StartsWith

a) left(@edition, 15) = 'Express Edition'
b) charindex('Express Edition', @edition) = 1

Содержит

charindex('Express Edition', @edition) >= 1

Примеры

left функция

set @isExpress = case when left(@edition, 15) = 'Express Edition' then 1 else 0 end

iif функция (начиная с SQL Server 2012)

set @isExpress = iif(left(@edition, 15) = 'Express Edition', 1, 0);

charindex функция

set @isExpress = iif(charindex('Express Edition', @edition) = 1, 1, 0);
68 голосов
/ 29 февраля 2012

Похоже, что вы хотите http://msdn.microsoft.com/en-us/library/ms186323.aspx.

В вашем примере это будет (начинается с):

set @isExpress = (CharIndex('Express Edition', @edition) = 1)

или содержит

set @isExpress = (CharIndex('Express Edition', @edition) >= 1)
31 голосов
/ 25 марта 2015

Я бы использовал

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
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...