我正在尝试检测服务器是否正在运行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');
答案 0 :(得分:92)
<强> 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);
set @isExpress = iif(charindex('Express Edition', @edition) = 1, 1, 0);
答案 1 :(得分:68)
看起来你想要的是http://msdn.microsoft.com/en-us/library/ms186323.aspx。
在你的例子中,它将是(以...开头):
set @isExpress = (CharIndex('Express Edition', @edition) = 1)
或包含
set @isExpress = (CharIndex('Express Edition', @edition) >= 1)
答案 2 :(得分:31)
我会用
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