Rumah >pembangunan bahagian belakang >C++ >Bagaimana untuk Membina Klausa Dynamic WHERE dengan OR dalam LINQ kepada Entiti?

Bagaimana untuk Membina Klausa Dynamic WHERE dengan OR dalam LINQ kepada Entiti?

Mary-Kate Olsen
Mary-Kate Olsenasal
2025-01-22 05:01:08665semak imbas

How to Build a Dynamic WHERE Clause with OR in LINQ to Entities?

Klausa (OR) Dinamik WHERE dalam LINQ kepada Entiti

Mencipta pertanyaan dinamik menggunakan operator OR dalam LINQ memerlukan PredicateBuilder, utiliti LINQKit. Begini cara melakukannya:

<code class="language-csharp">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();</code>

Walau bagaimanapun, menggunakan AsExpandable() ialah pilihan lain:

<code class="language-csharp">return query.AsExpandable().Where(pred).FirstOrDefault();</code>
Kaedah

Expand membenarkan pengendalian ungkapan panggilan yang tidak dapat dikendalikan oleh EF. Tanpa itu, pengecualian akan dilemparkan.

Pilihan Pembina Predikat lain yang mencapai fungsi yang sama tanpa Expand boleh didapati di http://petemontgomery.wordpress.com/2011/02/10/a-universal-predicatebuilder/.

Atas ialah kandungan terperinci Bagaimana untuk Membina Klausa Dynamic WHERE dengan OR dalam LINQ kepada Entiti?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn