Replikation von SQL-CASE-Anweisungen in LINQ für die dynamische Produktmengenzuordnung
In diesem Artikel wird gezeigt, wie die Funktionalität einer SQL-CASE-Anweisung in LINQ übersetzt wird, wobei insbesondere auf die Herausforderung der bedingten Zuweisung von Produktmengen basierend auf verschiedenen Kriterien eingegangen wird. Wir ändern den vorhandenen Code, um diese Logik zu integrieren.
Die anfängliche Berechnung:
<code class="language-csharp">cds_oeinvitem.itemqtyonhand - cds_oeinvitem.itemqtycommitted</code>
Diese einfache Subtraktion ermittelt den verfügbaren Bestand, indem zugesagte Mengen vom Lagerbestand abgezogen werden.
Das SQL-CASE-Anweisungsäquivalent in LINQ verwendet verschachtelte ternäre Operatoren:
<code class="language-csharp">osc_products.products_quantity = itempromoflag != "N" ? 100000 : ( itemcat1.In("1", "2", "31") && itemsalestatus == "S" ? 100000 : itemsalestatus == "O" ? 0 : cds_oeinvitem.itemqtyonhand - cds_oeinvitem.itemqtycommitted )</code>
Diese verschachtelte Struktur spiegelt die bedingte Logik einer CASE-Anweisung wider. Es priorisiert Bedingungen: Wenn itempromoflag
nicht „N“ ist, beträgt die Menge 100000; andernfalls geht es zur nächsten Bedingung über und so weiter.
Die integrierte LINQ-Abfrage:
<code class="language-csharp">cdsDBDataContext db = new cdsDBDataContext(); var query = from items in db.cdsItems where items.ItemHandHeldFlag == "Y" && ( items.Itempromoflag != "N" ? 100000 : ( items.Itemcat1.In("1", "2", "31") && items.Itemsalestatus == "S" ? 100000 : items.Itemsalestatus == "O" ? 0 : items.Itemqtyonhand - items.Itemqtycommitted ) ) > 0 select items;</code>
Diese überarbeitete Abfrage umfasst die bedingte Mengenzuweisung und stellt sicher, dass der Bestandsstatus basierend auf den definierten Kriterien genau aktualisiert wird. Es werden nur Artikel ausgewählt, die die Bedingung ItemHandHeldFlag
erfüllen und deren resultierende Menge größer als Null ist. Dies repliziert effektiv das Verhalten einer SQL-CASE-Anweisung innerhalb des LINQ-Frameworks.
Das obige ist der detaillierte Inhalt vonWie implementiert man ein SQL-CASE-Anweisungsäquivalent in LINQ für die bedingte Produktmengenzuweisung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!