T sql'de değişkenler içeren StartsWith veya Contains var mı?


96

Sunucunun Express Edition çalıştırıp çalıştırmadığını tespit etmeye çalışıyorum.

Aşağıdaki t sql'ye sahibim.

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

print @edition

Benim örneğimde, @edition = Express Edition (64-bit)

Aşağıdakileri nasıl yapabilirim? (C # esinlenmiştir).

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

Yanıtlar:


126

İle başlar

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

İçerir

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

Örnekler

left işlevi

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

iif işlev (SQL Server 2012'den itibaren)

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

charindex işlevi

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

1
Bunların dahili olarak farklı çalıştığını, özellikle de performansın ve indekslerin kullanımının farklı olduğunu unutmayın. Örneğin, bir kullanarak sorgu colName LIKE 'prefix%'çok hızlı ne zaman olacak colNameendeksli, ancak colName LIKE '%substring%'ya colName LIKE '%suffix'metin dizine eklerken SQL Server eki-ağaçları yaratmaz çünkü yavaş olacaktır. Benzer şekilde LEFTbir sütun ile kullanmak da yavaş olacaktır çünkü bu sorgular SARGable değildir. SARGability önemlidir: dba.stackexchange.com/questions/162263/…
Dai

Aşağıda belirtilen LIKE 'x%' yöntemini test etmenizi tavsiye ederim. Bazı durumlarda çok daha hızlıdır
Tony Sepia

72

Görünüşe göre, istediğiniz http://msdn.microsoft.com/en-us/library/ms186323.aspx .

Örneğinizde şöyle olacaktır (ile başlar):

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

Veya içerir

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

Neden LIKE kullanmıyorsunuz Express Edition%? Ayrıca, dizenin herhangi bir yerinde "Ekspres Sürüm" için çözümünüz doğru dönmüyor mu? Yani, daha spesifik olarak bunu yapmanın sadece bir "İçerir" şekli
Don Cheadle

3
@mmcrae Aşağıdaki benzer sürümü kullanmak iyi olurken, akla gelen ilk yol buydu ve en çok OP'nin sahip olduğu şeye benziyor. Ayrıca, ilk ifade yalnızca değişken verilen bağımsız değişkenle başlarsa (charindex 1 döndürür) doğru döndürür. İkinci ifade bir içerir çünkü eğer argüman dizenin herhangi bir yerinde bulunursa (charindex 1 veya daha büyük değerini döndürür).
Gary.S

47

Kullanmak istiyorum

like 'Express Edition%'

Misal:

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

Soruyu okursanız, bu bir sorgu değildir. Cevabınızla örneğimi deneyin ve ardından lütfen çalıştığını göstererek cevabınızı güncelleyin.
Valamas

T-sql'deki if-ifadelerindeki gibi kullanabilirsiniz. Bu yüzden beğeniyorum. Bunun için bana neden eksi puan vermek istediğini anlamıyorum ama neden olmasın.
Thomas Koelle

10
Bu tercih edilen yol olmalıdır; daha zarif, daha az ayrıntılı ve "SQL uyumlu": standart SQL LIKE operatörünü kullandığından, anlamak için belgeleri okumam gerekmiyor!
Fer García
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.