Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Melaksanakan OR Logik dengan Cekap dalam Klausa LINQ WHERE Dinamik?
Artikel sebelumnya memperkenalkan kaedah untuk membina pertanyaan dinamik menggunakan pelaksanaan tertunda LINQ. Walau bagaimanapun, pertanyaan ini menggunakan syarat DAN untuk menyertai klausa WHERE. Artikel ini meneroka cara menyesuaikan kaedah ini untuk menggunakan logik OR sebaliknya.
Matlamat khusus adalah untuk membuat pertanyaan yang mencari pengguna berdasarkan nama pengguna mereka, nama pengguna Windows atau kedua-duanya (ditentukan oleh penghitungan Jenis Identifier yang disediakan). Kaedah GetUser yang diubah suai adalah seperti berikut:
<code>public User GetUser(IdentifierType type, string identifier) { using (var context = contextFactory.Invoke()) { var query = from u in context.Users select u; var pred = Predicate.False<User>(); if (type.HasFlag(IdentifierType.Username)) pred = pred.Or(u => u.Username == identifier); if (type.HasFlag(IdentifierType.Windows)) pred = pred.Or(u => u.WindowsUsername == identifier); return query.Where(pred.Expand()).FirstOrDefault(); // 或者 return query.AsExpandable().Where(pred).FirstOrDefault(); } }</code>
Kunci untuk melaksanakan logik OR terletak pada PredicateBuilder perpustakaan LINQKit. Ia membenarkan pembinaan predikat dinamik dan boleh digunakan bersama dengan Rangka Kerja Entiti. Predikat bermula dengan Predicate.False dan diubah suai secara dinamik berdasarkan bendera IdentifierType.
Kaedah Expand() adalah penting kerana Rangka Kerja Entiti tidak menyokong ungkapan panggilan. AsExpandable() mengaktifkan pengakses ekspresi LINQKit dan menukar ungkapan ke dalam bentuk yang boleh dikendalikan oleh Rangka Kerja Entiti. Tanpanya, pengecualian "Invoke" akan berlaku.
Pendekatan lain ialah menggunakan pembina predikat Pete Montgomery, yang melaksanakan fungsi yang sama tanpa memerlukan Expand().
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan OR Logik dengan Cekap dalam Klausa LINQ WHERE Dinamik?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!