>백엔드 개발 >C++ >SQL CASE 문을 LINQ로 어떻게 변환할 수 있나요?

SQL CASE 문을 LINQ로 어떻게 변환할 수 있나요?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-03 11:41:40272검색

How Can I Convert SQL CASE Statements to LINQ?

LINQ CASE 문: 심층 분석

LINQ(Language Integrated Query)에서 CASE 문은 여러 조건을 평가하고 해당 조건에 따라 다른 값을 반환합니다. 제공된 CASE 문을 LINQ로 변환하려면 삼항 조건부 연산자나 람다 식을 활용하여 유사한 기능을 얻을 수 있습니다.

다음 예를 고려하세요.

// Original CASE statement
osc_products.products_quantity =
CASE 
    WHEN itempromoflag <> 'N' THEN 100000
    WHEN itemcat1 IN ('1','2','31') AND itemsalestatus = 'S' THEN 100000
    WHEN itemsalestatus = 'O' THEN 0
    ELSE cds_oeinvitem.itemqtyonhand - cds_oeinvitem.itemqtycommitted 
END  

이를 LINQ로 변환하려면 삼항 조건부 연산자를 사용할 수 있습니다:

var newQuantity = (itempromoflag != 'N') ? 100000 :
    ((itemcat1 == '1' || itemcat1 == '2' || itemcat1 == '31') && itemsalestatus == 'S') ? 100000 :
    (itemsalestatus == 'O') ? 0 :
    cds_oeinvitem.itemqtyonhand - cds_oeinvitem.itemqtycommitted;

또는 람다 표현식을 사용할 수도 있습니다. 더 간결한 표현:

var newQuantity = (itempromoflag != 'N') ? 100000 :
    ((itemcat1 == '1' || itemcat1 == '2' || itemcat1 == '31') && itemsalestatus == 'S') ? 100000 :
    (itemsalestatus == 'O') ? 0 :
    () => cds_oeinvitem.itemqtyonhand - cds_oeinvitem.itemqtycommitted;

이 예에서 삼항 연산자와 람다 표현식은 유사한 조건부 검사를 수행하고 충족되는 조건에 따라 적절한 값을 반환합니다.

위 내용은 SQL CASE 문을 LINQ로 어떻게 변환할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.