SQL Server 매개변수 설정 시 Null 허용 값 처리
SqlParameter
객체로 작업할 때 null 허용 값을 처리하려면 세심한 주의가 필요합니다. 정수 매개변수(예: SqlDbType.Int
)에 null 값을 직접 할당하면 "DBNull에서 int로의 암시적 변환이 없습니다."라는 오류가 발생하는 경우가 많습니다. 이는 유형 비호환으로 인해 발생합니다.
문제는 일반적으로 조건 연산자(?:
)를 사용할 때 나타납니다. 이 연산자는 int
또는 DBNull
의 가능성을 처리할 때 일관된 반환 유형을 결정하는 데 어려움을 겪습니다.
해결 방법: 객체 캐스팅 활용
한 가지 효과적인 접근 방식은 nullable 값을 object
에 캐스팅하는 것입니다. 이는 object
이 int
및 DBNull
값을 모두 수용할 수 있기 때문에 유형 모호성을 해결합니다.
<code class="language-csharp">SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int); planIndexParameter.Value = (object)AgeItem.AgeIndex ?? DBNull.Value;</code>
해결 방법: Null 병합 연산자 활용
또 다른 솔루션은 널 병합 연산자(??
)를 활용하는 것입니다. 이 연산자는 null이 아닌 경우 왼쪽 피연산자를 우아하게 반환합니다. 그렇지 않으면 오른쪽 피연산자를 반환합니다.
<code class="language-csharp">SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int); planIndexParameter.Value = AgeItem.AgeIndex ?? DBNull.Value;</code>
결정적으로 AgeItem.AgeIndex
이 null인 경우 planIndexParameter.Value
는 SQL Server에서 null 값을 표현하는 DBNull.Value
으로 설정됩니다.
이러한 방법 중 하나를 구현하면 SqlParameter
개체 내에서 null 값을 안정적으로 처리하여 일반적인 오류를 방지할 수 있습니다.
위 내용은 Nullable SQL Server 매개 변수를 처리할 때 'DBNull에서 int로의 암시적 변환 없음' 오류를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!