是否有带变量的ssql中的StartsWith或Contains?

时间:2012-02-29 05:05:55

标签: sql sql-server-2008 tsql

我正在尝试检测服务器是否正在运行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 个答案:

答案 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);

charindex功能

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