SqlDataReader 개체에서 열 존재 확인
데이터 액세스 계층에서는 저장 프로시저에서 반환된 데이터를 처리하는 메서드를 생성해야 하는 경우가 많습니다. 다양한 기둥 구조를 가지고 있습니다. 하나의 저장 프로시저가 다른 저장 프로시저에 비해 추가 열을 반환하는 시나리오의 경우 두 시나리오를 모두 처리하도록 메서드를 수정해야 합니다. 이 문서에서는 SqlDataReader 개체에 특정 열이 있는지 확인하는 방법을 설명합니다.
해결책:
제안되는 해결 방법은 IDataRecord 인터페이스에 대한 확장 메서드를 만드는 것입니다. HasColumn이라는 이름이 붙었습니다. 이 방법은 열 이름을 매개변수로 사용하고 레코드의 모든 열을 반복하여 각 열 이름을 제공된 이름과 비교합니다. 일치하는 항목이 발견되면 true를 반환하여 해당 열이 있음을 나타냅니다. 그렇지 않으면 false를 반환합니다.
HasColumn 확장 메서드에 대한 코드는 다음과 같습니다.
public static class DataRecordExtensions { public static bool HasColumn(this IDataRecord dr, string columnName) { for (int i = 0; i < dr.FieldCount; i++) { if (dr.GetName(i).Equals(columnName, StringComparison.InvariantCultureIgnoreCase)) return true; } return false; } }
사용법:
SqlDataReader 개체가 있는지 확인하려면 특정 열이 포함되어 있는 경우 해당 개체에서 HasColumn 메서드를 호출하고 관심 있는 열 이름을 전달하면 됩니다. 메서드는 열이 존재하면 true를 반환하고, 그렇지 않으면 false를 반환합니다. 이를 통해 저장 프로시저의 다양한 열 구조를 강력한 방식으로 처리할 수 있습니다.
위 내용은 SqlDataReader에서 열 존재 여부를 어떻게 확인할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!