SORU
26 HAZİRAN 2013, ÇARŞAMBA


Dinamik olarak kendi başına 1=1 kullanarak daha bir SQL WHERE yan inşa etmek için daha iyi bir yolu var mı?

C SQL Bazı sorgu yapıyorum#. Bazı koşullar kodda değişkenler olarak depolanan bağlı olarak farklı olacaktır.

string Query="SELECT * FROM Table1 WHERE 1=1 ";
if (condition1) 
    Query  = "AND Col1=0 ";
if (condition2) 
    Query  = "AND Col2=1 ";
if (condition3) 
    Query  = "AND Col3=2 ";

Çalışıyor ama 1=1 test zarif görünmüyor. Eğer bunu kullanmadım bile, unutma ve her zaman kontrol etmek gerekir "nerede" sözcüğü zaten sorgu için eklendi.

Daha iyi bir çözüm var mı?

CEVAP
26 HAZİRAN 2013, ÇARŞAMBA


Liste: koşullar kaydedin

List<string> conditions = new List<string>();

if (condition1) conditions.Add("Col1=0");
//...
if (conditions.Any())
    Query  = " WHERE "   string.Join(" AND ", conditions.ToArray());

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

YORUMLAR

SPONSOR VİDEO

Rastgele Yazarlar

  • discokatze

    discokatze

    23 EYLÜL 2009
  • ETrade Supply

    ETrade Suppl

    23 Temmuz 2011
  • WoodysGamertag

    WoodysGamert

    17 Aralık 2009