LINQ 쿼리의 Null 값 처리: 유형 변환 실패 해결
LINQ 쿼리가 null 값을 반환할 수 있는 경우 "값 형식 'Int32'를 null로 변환할 수 없습니다. 결과 형식 또는 쿼리의 일반 매개 변수는 null 허용 형식을 사용해야 합니다."라는 오류가 발생할 수 있습니다. 오류가 발생하고 null 값을 허용하려면 다음 접근 방식을 고려하세요.
방법 1: DefaultIfEmpty 및 Sum을 사용하고 기본값을 지정합니다.
<code class="language-csharp">var creditsSum = (from u in context.User join ch in context.CreditHistory on u.ID equals ch.UserID where u.ID == userID select ch.Amount).DefaultIfEmpty(0).Sum();</code>
이 방법은 DefaultIfEmpty
테이블에 일치하는 레코드가 없을 때 CreditHistory
을 사용하여 기본값(이 경우 0)을 삽입합니다.
방법 2: null 허용 유형으로 변환하고 ?? 연산자 사용
<code class="language-csharp">var creditsSum = (from u in context.User join ch in context.CreditHistory on u.ID equals ch.UserID where u.ID == userID select (int?)ch.Amount).Sum() ?? 0;</code>
이 방법에서는 Amount
속성을 null 허용 유형(int?
)으로 변환하도록 쿼리가 수정됩니다. 이는 값이 null일 수 있음을 컴파일러에 알립니다. 그런 다음 ??
연산자를 사용하여 null 값의 경우를 처리하고 값이 null이면 기본값(이 경우 0)을 할당합니다.
방법 3: Coalesce 기능 사용
<code class="language-csharp">var creditsSum = (from u in context.User join ch in context.CreditHistory on u.ID equals ch.UserID where u.ID == userID select COALESCE(ch.Amount, 0)).Sum();</code>
이 방법은 COALESCE
함수를 사용하여 SQL 쿼리에서 null 값을 지정된 기본값(이 경우 0)으로 직접 대체합니다.
위 내용은 캐스트 실패를 방지하기 위해 LINQ 쿼리에서 Null 값을 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!