มี StartsWith หรือมีใน t sql พร้อมตัวแปรหรือไม่


96

ฉันกำลังพยายามตรวจสอบว่าเซิร์ฟเวอร์กำลังเรียกใช้ 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');

คำตอบ:


126

เริ่มต้นด้วย

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
โปรดทราบว่าสิ่งเหล่านี้ภายในทำงานแตกต่างกันโดยเฉพาะประสิทธิภาพของ wrt และการใช้ดัชนี ตัวอย่างเช่นแบบสอบถามที่ใช้ colName LIKE 'prefix%'จะเร็วมากเมื่อcolNameมีการจัดทำดัชนี แต่colName LIKE '%substring%'หรือcolName LIKE '%suffix'จะช้าเนื่องจาก SQL Server ไม่สร้างต้นไม้ต่อท้ายเมื่อทำดัชนีข้อความ ในทำนองเดียวกันการใช้LEFTกับคอลัมน์ก็จะช้าเช่นกันเนื่องจากการสืบค้นเหล่านั้นไม่ได้ SARGable SARGability เป็นสิ่งสำคัญ: dba.stackexchange.com/questions/162263/...
Dai

ฉันอยากจะแนะนำให้ทดสอบวิธี LIKE 'x%' ที่กล่าวถึงด้านล่าง ในบางกรณีมันเร็วกว่ามาก
Tony Sepia

72

ดูเหมือนว่าสิ่งที่คุณต้องการคือhttp://msdn.microsoft.com/en-us/library/ms186323.aspx

ในตัวอย่างของคุณจะเป็น (เริ่มต้นด้วย):

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

หรือประกอบด้วย

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

ทำไมไม่ใช้ LIKE Express Edition%? นอกจากนี้โซลูชันของคุณไม่ส่งคืน "Express Edition" ที่เป็นจริงในสตริงหรือไม่ ดังนั้นมันจึงเป็นวิธีที่เฉพาะเจาะจงมากขึ้นเท่านั้น
Don Cheadle

3
@mmcrae ในขณะที่ใช้เวอร์ชันที่คล้ายกันด้านล่างนี้เป็นวิธีแรกที่นึกถึงและดูเหมือนว่า OP มีมากที่สุด นอกจากนี้นิพจน์แรกจะคืนค่าจริงก็ต่อเมื่อตัวแปรเริ่มต้นด้วย (charindex ส่งกลับ 1) อาร์กิวเมนต์ที่กำหนด นิพจน์ที่สองคือมีเนื่องจากจะส่งคืนจริงหากพบอาร์กิวเมนต์ที่ใดก็ได้ในสตริง (charindex ส่งกลับ 1 หรือมากกว่า)
Gary.S

47

ฉันจะใช้

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

หากคุณอ่านคำถามแล้วมันไม่ใช่คำถาม ลองใช้ตัวอย่างของฉันพร้อมกับคำตอบของคุณแล้วโปรดอัปเดตคำตอบของคุณที่แสดงว่าได้ผล
Valamas

คุณสามารถใช้เช่นใน if-statement ใน t-sql นี่คือเหตุผลที่ฉันใช้เช่น. ฉันไม่เห็นว่าทำไมคุณถึงอยากให้คะแนนลบกับฉัน แต่ทำไมไม่
Thomas Koelle

10
นี่ควรเป็นวิธีที่ต้องการ มันดูหรูหรากว่า verbose น้อยกว่าและ "จัดเรียง SQL": เนื่องจากใช้ตัวดำเนินการ SQL LIKE มาตรฐานฉันจึงไม่จำเป็นต้องอ่านเอกสารเพื่อทำความเข้าใจ!
Fer García
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.