web-dev-qa-db-fra.com

Y a-t-il StartsWith ou Contains dans t sql avec des variables?

J'essaie de détecter si le serveur exécute Express Edition.

J'ai le t sql suivant.

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

print @edition

Dans mon cas, @edition = Express Edition (64-bit)

Comment puis-je faire ce qui suit? (Inspiré de C #).

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

StartsWith

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

contient

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

Exemples

left fonction

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

iif fonction (à partir de SQL Server 2012)

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

charindex fonction

set @isExpress = iif(charindex('Express Edition', @edition) = 1, 1, 0);
99
Kirill Polishchuk

Il semble que ce que vous voulez soit http://msdn.Microsoft.com/en-us/library/ms186323.aspx .

Dans votre exemple, ce serait (commence par):

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

Ou contient

set @isExpress = (CharIndex('Express Edition', @edition) >= 1)
69
Gary.S

J'utiliserais

like 'Express Edition%'

Exemple:

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
31
Thomas Koelle