Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Memilih Rekod Berbeza Berdasarkan Medan Khusus dalam LINQ?

Bagaimana untuk Memilih Rekod Berbeza Berdasarkan Medan Khusus dalam LINQ?

Susan Sarandon
Lepaskan: 2025-01-03 06:40:38
asal
791 orang telah melayarinya

How to Select Distinct Records Based on a Specific Field in LINQ?

Memilih Rekod Berbeza Berdasarkan Medan Tunggal dalam LINQ

Apabila bekerja dengan data dalam LINQ, mungkin perlu menapis rekod pendua , memastikan hanya nilai unik dikembalikan. Walau bagaimanapun, daripada menghapuskan keseluruhan baris pendua, mungkin lebih baik untuk melaksanakan operasi ini berdasarkan medan atau sifat tertentu.

Pertanyaan Asas Berbeza

Pertanyaan LINQ berikut menunjukkan cara asas untuk menggunakan kaedah Distinct() untuk menghapuskan pendua baris:

var query = (from r in table1
orderby r.Text
select r).Distinct();
Salin selepas log masuk

Pertanyaan ini mendapatkan semula semua baris daripada jadual1 yang diisih mengikut medan Teks dan kemudian mengalih keluar sebarang pendua daripada set yang terhasil.

Berbeza pada Medan Tertentu

Tetapi bagaimana jika matlamatnya adalah untuk mengembalikan hanya baris di mana medan tertentu, seperti Teks, mengandungi nilai unik? Untuk mencapai matlamat ini, satu pilihan ialah menggunakan kaedah GroupBy() diikuti dengan kaedah Select():

table1.GroupBy(x => x.Text).Select(x => x.FirstOrDefault());
Salin selepas log masuk

Dalam pertanyaan ini, jadual1 pertama dikumpulkan mengikut medan Teks, mencipta kumpulan untuk setiap unik Nilai teks. Kemudian, untuk setiap kumpulan, kaedah FirstOrDefault() digunakan untuk memilih baris pertama. Hasilnya ialah koleksi baris yang medan Teks mengandungi nilai yang berbeza.

Atas ialah kandungan terperinci Bagaimana untuk Memilih Rekod Berbeza Berdasarkan Medan Khusus dalam LINQ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan