>백엔드 개발 >C++ >C#에서 'DBNull을 Int로 암시적으로 변환할 수 없습니다' 오류를 처리하는 방법은 무엇입니까?

C#에서 'DBNull을 Int로 암시적으로 변환할 수 없습니다' 오류를 처리하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-10 22:57:48187검색

How to Handle

DBNull을 Int로 암시적으로 변환할 수 없나요?

코드 조각 오류: "DBNull에서 int로 암시적으로 변환할 수 없습니다." 이는 ?: 연산자의 특성 때문입니다. 왜냐하면 이 연산자가 평가하는 표현식이 동일한 유형이어야 하기 때문입니다.

이 예에서 첫 번째 표현식(AgeItem.AgeIndex)은 정수이고 두 번째 표현식(DBNull.Value)은 DBNull 유형입니다. 이러한 유형은 호환되지 않아 오류가 발생합니다.

해결책: 객체로 캐스팅하거나 null 병합 연산자를 사용합니다.

이 문제를 해결하려면 두 가지 옵션이 있습니다.

  • 객체로 캐스팅: AgeItem.AgeIndex를 정수 및 DBNull 값을 수용할 수 있는 객체 유형으로 캐스팅:
<code class="language-csharp">SqlParameter[] parameters = new SqlParameter[1];     
SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int);
planIndexParameter.Value = (object)AgeItem.AgeIndex ?? DBNull.Value;
parameters[0] = planIndexParameter; </code>
  • Null 병합 연산자 사용(??): ??Null 병합 연산자는 첫 번째 표현식이 Null이 아닌 경우 첫 번째 표현식의 값을 반환하고 두 번째 표현식의 값을 반환합니다. . AgeItem.AgeIndex가 null인 경우 DBNull.Value를 할당하는 데 사용할 수 있습니다.
<code class="language-csharp">SqlParameter[] parameters = new SqlParameter[1];     
SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int);
planIndexParameter.Value = AgeItem.AgeIndex ?? DBNull.Value;
parameters[0] = planIndexParameter; </code>

이러한 솔루션을 사용하면 유형 변환 오류 없이 SqlParameter에 정수 또는 DBNull.Value를 할당할 수 있습니다.

위 내용은 C#에서 'DBNull을 Int로 암시적으로 변환할 수 없습니다' 오류를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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