Zugreifen auf XML-Daten
Aktualisiert: November 2007
Es gibt zwei verschiedene Methoden zum Abrufen von XML-Daten aus einer Datenquelle: Die eine verwendet CStreamRowset, und die andere verwendet CXMLAccessor.
Funktionalität |
CStreamRowset |
CXMLAccessor |
---|---|---|
Menge der übertragenen Daten |
Ruft Daten aus allen Spalten und Zeilen gleichzeitig ab. |
Ruft Daten aus allen Spalten ab, jedoch für jede Spalte einzeln. Sie müssen mithilfe von Methoden (z. B. MoveNext) durch Zeilen navigieren. |
Formatieren der Zeichenfolge |
SQL Server formatiert die XML-Zeichenfolge und sendet sie an den Consumer. |
Ruft Rowsetdaten im systemeigenen Format ab. (Der Anbieter muss diese als Unicode-Zeichenfolgen übermitteln.) Erstellt anschließend die Zeichenfolge mit den Daten im XML-Format. |
Steuerung der Formatierung |
Sie können die Formatierung der XML-Zeichenfolge bis zu einem gewissen Grad steuern, indem Sie einige SQL Server 2000-spezifische Eigenschaften einstellen. |
Sie haben keine Möglichkeit, das Format der generierten XML-Zeichenfolge zu steuern. |
CStreamRowset stellt zwar insgesamt die effizientere Art zum Abrufen von Daten im XML-Format dar, sie wird jedoch nur von SQL Server 2000 unterstützt.
Abrufen von XML-Daten mit CStreamRowset
Sie müssen CStreamRowset als Rowsettyp in der CCommand-Deklaration oder CTable-Deklaration angeben. Sie können hierbei einen eigenen Accessor oder gar keinen Accessor verwenden, beispielsweise:
CCommand< CAccessor<CMyAccessor>, CStreamRowset > myCmd;
- oder -
CCommand< CNoAccessor, CStreamRowset > myCmd;
Wenn Sie CCommand::Open aufrufen (und dabei z. B. CRowset als die TRowset-Klasse angeben) erhält diese gewöhnlich einen IRowset-Zeiger. ICommand::Execute gibt einen IRowset-Zeiger zurück, der im m_spRowset-Member des CRowset-Objekts gespeichert wird. Methoden wie MoveFirst, MoveNext und GetData verwenden diesen Zeiger zum Abrufen der Daten.
Wenn Sie im Gegensatz hierzu CCommand::Open aufrufen (aber CStreamRowset als TRowset-Klasse angeben), gibt ICommand::Execute einen ISequentialStream-Zeiger zurück, der im m_spStream-Datenmember von CStreamRowset gespeichert wird. Anschließend verwenden Sie die Read-Methode, um die Daten (Unicode-Zeichenfolge) im XML-Format abzurufen. Beispiel:
myCmd.m_spStream->Read()
SQL Server 2000 führt die XML-Formatierung durch und gibt alle Spalten und Zeilen des Rowsets als eine XML-Zeichenfolge zurück.
Ein Beispiel zur Verwendung der Read-Methode finden Sie unter "Hinzufügen von XML-Unterstützung zum Consumer" in Implementieren eines einfachen Consumers.
Hinweis: |
---|
XML-Unterstützung mit CStreamRowset ist nur mit SQL Server 2000 möglich und setzt den OLE DB Anbieter für SQL Server 2000 (mit MDAC installiert) voraus. |
Abrufen von XML-Daten mit CXMLAccessor
Wenn das Schema eines Datenspeichers unbekannt ist, ermöglicht CXMLAccessor den Zugriff auf Daten aus einer Datenquelle in Form von Zeichenfolgendaten. Die Funktionsweise von CXMLAccessor ist mit der von CDynamicStringAccessorW identisch, erstere formatiert jedoch alle Daten, auf die vom Datenspeicher zugegriffen werden, mit XML-Tags. Dabei wird eine größtmögliche Entsprechung zwischen den XML-Tagnamen und den Spaltennamen des Datenspeichers angestrebt.
Verwenden Sie CXMLAccessor wie jede andere Accessorklasse, indem Sie sie als einen Vorlagenparameter an CCommand oder CTable übergeben:
CTable<CXMLAccessor, CRowset> rs;
Verwenden Sie GetXMLRowData zum zeilenweisen Abrufen von Daten aus der Tabelle und zum Navigieren durch Zeilen mithilfe von Methoden (z. B. MoveNext). Beispiel:
// Open data source, session, and rowset
hr = rs.MoveFirst();
while( SUCCEEDED(hr) && hr != DB_S_ENDOFROWSET )
{
CStringW strRowData;
myCmd.GetXMLRowData(strRowData);
printf_s( "%S\n", strRowData );
hr = rs.MoveNext();
}
Sie können GetXMLColumnData verwenden, um Spalteninformationen (Datentypinformationen) als XML-formatierte Zeichenfolgedaten abzurufen.