Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Melaksanakan Pernyataan 'IN' SQL Menggunakan LINQ?

Bagaimana untuk Melaksanakan Pernyataan 'IN' SQL Menggunakan LINQ?

Patricia Arquette
Lepaskan: 2024-12-30 12:19:10
asal
835 orang telah melayarinya

How to Implement SQL's

Pelaksanaan Linq bagi Pernyataan "IN" SQL

Dalam konteks skema penandaan dengan jadual Item, Teg dan TagMap, anda mencari pertanyaan LINQ yang mendapatkan semula item yang sepadan dengan senarai ID teg yang ditentukan. Dalam SQL, ini biasanya dicapai menggunakan pernyataan IN.

Untuk menterjemahkannya ke dalam LINQ, anda boleh menggunakan kaedah Contains(). Pertimbangkan contoh berikut:

var TagIds = new int[] {12, 32, 42};

var q = from map in Context.TagMaps
        where TagIds.Contains(map.TagId)
        select map.Items;
Salin selepas log masuk

Dalam pertanyaan ini:

  • Konteks.TagMaps mewakili jadual TagMap.
  • Klausa where menyemak sama ada sifat TagId bagi setiap contoh TagMap terkandung dalam tatasusunan TagId bagi teg yang diingini ID.
  • Klausa pilih mendapatkan semula sifat Item bagi setiap TagMap yang sepadan.

Pertanyaan ini akan menghasilkan pernyataan SQL IN serupa dengan:

SELECT * FROM Items
WHERE TagId IN (12, 32, 42)
Salin selepas log masuk

Pertanyaan ini pertanyaan yang terhasil akan mengembalikan item yang mempunyai sekurang-kurangnya satu teg dengan ID dalam senarai yang ditentukan.

Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Pernyataan 'IN' SQL Menggunakan 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