CXMLAccessor クラス
更新 : 2007 年 11 月
データ ストアのスキーマ (基となる構造) に関する情報がまったくない場合にも文字列データとしてデータ ソースにアクセスできます。
class CXMLAccessor : public CDynamicStringAccessorW
解説
ただし、CXMLAccessor は、データ ストアからアクセスするすべてのデータを XML 書式 (タグ付き) データに変換する点で、CDynamicStringAccessorW とは異なります。これは、特に XML 対応 Web ページへの出力のために役立ちます。XML タグ名は、データ ストアの列名に可能な限り一致するように付けられます。
列情報を取得するには CDynamicAccessor メソッドを使用します。この列の情報は、実行時にアクセサを動的に作成するときに使用します。
列情報は、このクラスによって作成および管理されるバッファに格納されます。GetXMLColumnData を使用して列情報を取得するか、GetXMLRowData を使用して行ごとに列データを取得します。
使用例
void DoCXMLAccessorTest()
{
HRESULT hr = CoInitialize(NULL);
CDataSource ds;
CSession ss;
CTable<CXMLAccessor> rs;
// The following is an example initialization string:
hr = ds.OpenFromInitializationString(L"Provider=Microsoft.Jet.OLEDB.4.0;"
L"User ID=Admin;Data Source=Snippet.mdb;Mode=Share Deny None;"
L"Extended Properties=\"\";Jet OLEDB:System database=\"\";"
L"Jet OLEDB:Registry Path=\"\";Jet OLEDB:Database Password=\"\";"
L"Jet OLEDB:Engine Type=5;Jet OLEDB:Database Locking Mode=1;"
L"Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;"
L"Jet OLEDB:New Database Password=\"\";Jet OLEDB:Create System Database=False;"
L"Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;"
L"Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False");
hr = ss.Open(ds);
hr = rs.Open(ss, L"Customer"); // Customer is a table name in the database.
CStringW strColumnInfo;
rs.GetXMLColumnData(strColumnInfo);
wprintf_s(L"%s\n", strColumnInfo);
hr = rs.MoveFirst();
while(SUCCEEDED(hr) && hr != DB_S_ENDOFROWSET)
{
CStringW strRowData;
rs.GetXMLRowData(strRowData);
wprintf_s(L"%s\n", strRowData);
hr = rs.MoveNext();
}
ss.Close();
ds.Close();
CoUninitialize();
}
必要条件
ヘッダー : atldbcli.h