관계형 데이터 및 ADO.NET과의 XML 통합
XmlDataDocument 클래스는 XmlDocument의 파생 클래스이며 XML 데이터를 포함합니다. XmlDataDocument의 이점은 관계형 데이터와 계층형 데이터 간을 연결해 준다는 것입니다. XmlDocument는 DataSet에 바인딩할 수 있는 클래스입니다. 이러한 두 클래스는 모두 클래스에 포함된 데이터의 변경 내용을 동기화할 수 있습니다. DataSet에 바인딩된 XmlDocument를 통해 XML을 관계형 데이터와 통합할 수 있으므로 데이터를 XML 또는 관계형 형식으로 나타낼 필요가 없습니다. 데이터를 두 가지 형식으로 나타낼 수 있으며 한 가지 형식으로만 제약되지 않습니다.
두 가지 뷰로 데이터를 사용할 수 있기 때문에 다음과 같은 이점을 얻을 수 있습니다.
XML 문서의 구조화된 부분을 데이터 세트에 매핑할 수 있으며 효율적으로 저장하고 인덱싱하거나 검색할 수 있습니다.
커서 모델을 통해 관계형으로 저장되는 XML 데이터에 대한 변형, 유효성 검사 및 탐색 작업을 효율적으로 수행할 수 있습니다. 경우에 따라 이 작업은 XML이 XmlDocument 모델에 저장되어 있는 경우보다 관계형 구조에 대해 좀 더 효율적으로 수행될 수 있습니다.
DataSet은 XML의 일부를 저장할 수 있습니다. 즉, XPath 또는 XslTransform을 사용하여 관련된 요소 및 특성만 DataSet에 저장할 수 있습니다. 해당 DataSet에서 필터링된 보다 적은 데이터 하위 집합이 변경되고 변경 내용은 XmlDataDocument의 더 큰 데이터로 전파될 수 있습니다.
또한 SQL Server에서 DataSet으로 로드된 데이터를 변환할 수도 있습니다. 다른 옵션은 .NET Framework 클래스 스타일의 관리되는 WinForm 및 WebForm 컨트롤을 XML 입력 스트림으로부터 채워진 DataSet에 바인딩하는 것입니다.
XmlDataDocument는 XslTransform을 지원할 뿐 아니라 XPath 쿼리 및 유효성 검사를 위해 관계형 데이터를 노출합니다. 기본적으로 관계형 데이터에 대해 모든 XML 서비스를 사용할 수 있으며 XML 신뢰도를 떨어뜨리지 않으면서 구조적으로 투영된 XML에 대해 컨트롤 바인딩, 코드 생성 등과 같은 관계형 기능을 사용할 수 있습니다.
XmlDataDocument는 XmlDocument에서 상속되므로 W3C DOM의 구현을 제공합니다. XmlDataDocument가 DataSet과 연관되어 있고 DataSet 내부에 해당 데이터 하위 세트를 저장하므로 DataSet은 XmlDocument의 용도를 제한하거나 변경하지 않습니다. XmlDocument를 사용하도록 작성된 코드는 XmlDataDocument에 대해서도 동일하게 작동됩니다. DataSet은 테이블, 열, 관계 및 제약 조건을 정의하여 동일한 데이터를 관계형으로 표시하는 독립 실행형, 메모리 내 사용자 데이터 저장소입니다.
다음 그림은 XML 데이터의 DataSet 및 XmlDataDocument와의 다양한 연관성을 보여줍니다.
이 그림은 XML 데이터를 DataSet으로 직접 로드할 수 있으며 이를 통해 XML을 관계형 방식으로 직접 조작할 수 있음을 보여줍니다. 또는 XML을 XmlDataDocument에 해당하는 DOM의 파생 클래스로 로드할 수 있으며, 나중에 로드하여 DataSet과 동기화할 수 있습니다. DataSet 및 XmlDataDocument는 단일 데이터 세트에 대해 동기화되므로 한 저장소에서 데이터를 변경하면 해당 변경 내용이 다른 저장소에 반영됩니다.
XmlDataDocument는 XmlDocument에서 모든 편집 및 탐색 기능을 상속합니다. DataSet과 동기화된 XmlDataDocument 및 해당하는 상속된 기능을 사용하는 것이 DataSet으로 XML을 직접 로드하는 것보다 더 적절한 옵션인 경우가 있습니다. 다음 표에서는 DataSet을 로드하는 데 사용할 방법을 선택할 때 고려해야 할 항목을 보여줍니다.
XML을 DataSet으로 직접 로드해야 할 때 | XmlDataDocument를 DataSet과 동기화해야 할 때 |
---|---|
DataSet의 데이터 쿼리는 XPath보다 SQL을 사용하면 더 쉽게 처리할 수 있습니다. | DataSet의 데이터에 대해 XPath 쿼리가 필요합니다. |
소스 XML에서 요소 순서를 유지하지 않아도 됩니다. | 소스 XML에서 요소 순서를 유지해야 합니다. |
소스 XML에서 요소 간의 공백과 서식을 유지할 필요가 없습니다. | 소스 XML에서 공백과 서식을 유지해야 합니다. |
필요한 DataSet 주소에서 직접 XML을 로드하거나 해당 주소에 직접 XML을 쓰는 경우 XML로부터 DataSet 로드 및 DataSet을 XML 데이터로 작성을 참조하세요.
필요한 XmlDataDocument 주소에서 DataSet을 로드하는 경우 데이터 세트를 XML 문서와 동기화를 참조하세요.
참고 항목
.NET