Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Menggantikan Fungsi ISNULL SQL dengan LINQ?

Bagaimana untuk Menggantikan Fungsi ISNULL SQL dengan LINQ?

Mary-Kate Olsen
Lepaskan: 2024-12-29 16:59:11
asal
828 orang telah melayarinya

How to Replace SQL's ISNULL Function with LINQ?

LINQ Equivalent of SQL's ISNULL Function

Soalan:

Bagaimana anda boleh meniru tingkah laku fungsi ISNULL SQL dalam pertanyaan LINQ? Pertimbangkan pertanyaan gabungan yang melibatkan lajur tidak boleh dibatalkan (xx.Dalam talian jenis bit) yang boleh mengandungi nilai nol.

Jawapan:

Untuk mengendalikan nilai nullable dalam LINQ , anda boleh menggunakan operator bersyarat (? :) untuk menentukan nilai lalai jika objek aa adalah nol. Kod berikut menunjukkan perkara ini:

select new {
    AssetID = x.AssetID,
    Status = aa == null ? (bool?)null : aa.Online; // a Nullable<bool>
}
Salin selepas log masuk

Jika anda ingin menetapkan lalai kepada palsu (bukan null) apabila aa adalah batal, anda boleh menggunakan kod ini:

select new {
    AssetID = x.AssetID,
    Status = aa == null ? false : aa.Online;
}
Salin selepas log masuk

Penyiasatan Tambahan:

Adalah penting untuk ambil perhatian bahawa menggunakan operator bersyarat dengan nilai nol untuk jenis yang tidak boleh dibatalkan memerlukan pengendalian yang jelas. Dalam contoh yang diberikan, anda mengembalikan Nullable dalam blok kod pertama, yang membolehkan kedua-dua nilai nol dan palsu. Sebaliknya, blok kod kedua mengembalikan bool, jadi null mesti ditetapkan secara eksplisit kepada false jika aa adalah null.

Bagaimana ISNULL Berbanding dengan Operator Gabungan Null:

Operator penggabungan nol (??) tidak boleh digunakan secara langsung untuk menggantikan ISNULL. ke?? operator hanya mengembalikan nilai bukan nol jika kedua-dua operan adalah bukan nol. Oleh itu, ia tidak sesuai untuk mengendalikan situasi di mana satu operan mungkin batal.

Atas ialah kandungan terperinci Bagaimana untuk Menggantikan Fungsi ISNULL SQL dengan 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