SORU
13 EYLÜL 2011, Salı


ISNULL vs kullanarak belirli bir condtion kontrol etmek için BİRLEŞİM?

Birden çok parametre BİRLEŞİM geçirilen, ama istediğiniz zaman, bu özel bir durum ile ilgili olduğunu biliyorum eğer öyle olsaydı zaten bir ifadeyi kontrol, varsayılan kullanıyor musunuz ya da ISNULL yerine kullanmak için iyi bir uygulama mı?

İkisi arasında herhangi bir performans artışı var mı?

CEVAP
29 ŞUBAT 2012, ÇARŞAMBA


This problem reported on MIcrosoft Connect COALESCE ISNULL arasında bazı farklılıklar ortaya koymaktadır:

bizim işleme erken bir parçası CASE WHEN expression1 IS NOT NULL THEN expression1 ELSE expression2 END COALESCE( expression1, expression2 ) yeniden yazar. [Bu örnek]:

COALESCE ( ( SELECT Nullable
               FROM Demo
              WHERE SomeCol = 1 ), 1 )

biz oluşturun

SELECT CASE
          WHEN (SELECT Nullable FROM Demo WHERE SomeCol = 1) IS NOT NULL
          THEN (SELECT Nullable FROM Demo WHERE SomeCol = 1)
          ELSE 1
       END

Daha sonra sorgu işleme aşamaları iki alt alt sorgu iki kez yaparlar, yani aslında aynı ifade vardı, anlamıyor...

Bunu önermekten nefret ederim ama bir geçici çözüm, ikinci sorgu yinelenen olmadığından BİRLEŞİM ISNULL değiştirmek için.

Bunu Paylaş:
  • Google+
  • E-Posta
Etiketler:

YORUMLAR

SPONSOR VİDEO

Rastgele Yazarlar

  • Ammine Getahun

    Ammine Getah

    21 HAZİRAN 2011
  • Elly

    Elly

    3 EKİM 2005
  • ThePhestor

    ThePhestor

    22 Mart 2011