Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Menentukan Harta Isih Secara Dinamik dalam Klausa LINQ OrderBy?
Gunakan parameter dinamik untuk menyesuaikan ungkapan OrderBy dalam LINQ
Kaedah lanjutan OrderBy LINQ membolehkan anda mengisih koleksi objek berdasarkan satu atau lebih sifat. Tetapi bagaimana anda menentukan sifat mana yang hendak diisih menggunakan nilai yang diluluskan sebagai parameter?
Latar belakang:
Kod berikut menunjukkan penggunaan asas OrderBy, yang sifatnya dikodkan keras:
<code class="language-csharp">List<student> existingStudends = new List<student>{ new Student {...}, new Student {...}}; List<student> orderbyAddress = existingStudends.OrderBy(c => c.Address).ToList();</code>
Spesifikasi atribut dinamik:
Untuk menentukan sifat yang hendak diisih secara dinamik, anda boleh memanfaatkan refleksi untuk membina pepohon ekspresi yang diperlukan. Berikut ialah kaedah sambungan yang melaksanakan fungsi ini:
<code class="language-csharp">public static IQueryable<TEntity> OrderBy<TEntity>(this IQueryable<TEntity> source, string orderByProperty, bool desc) { string command = desc ? "OrderByDescending" : "OrderBy"; var type = typeof(TEntity); var property = type.GetProperty(orderByProperty); var parameter = Expression.Parameter(type, "p"); var propertyAccess = Expression.MakeMemberAccess(parameter, property); var orderByExpression = Expression.Lambda(propertyAccess, parameter); var resultExpression = Expression.Call(typeof(Queryable), command, new Type[] { type, property.PropertyType }, source.Expression, Expression.Quote(orderByExpression)); return source.Provider.CreateQuery<TEntity>(resultExpression); }</code>
di mana orderByProperty
ialah nama harta yang ingin anda isi dan desc
menentukan sama ada untuk mengisih dalam tertib menurun (benar) atau tertib menaik (salah).
Penggunaan:
Menggunakan kaedah sambungan ini, anda kini boleh mengisih mengikut mana-mana atribut secara dinamik:
<code class="language-csharp">string param = "City"; List<student> orderbyAddress = existingStudends.OrderBy("City", true).ToList(); // 按城市降序排序 List<student> orderbyName = existingStudends.OrderBy("Name", false).ToList(); // 按名称升序排序</code>
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menentukan Harta Isih Secara Dinamik dalam Klausa LINQ OrderBy?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!