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');
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);
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)
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