可以访问数据源以字符串数据,在您不了解数据存储区的架构 (基础结构)。
class CXMLAccessor : public CDynamicStringAccessorW
成员
方法
检索列信息。 |
|
按行检索表的整个内容。 |
备注
但是,CXMLAccessor 与 CDynamicStringAccessorW 的区别在于它从数据存储访问的所有数据都转换为 XML 格式的 (即带标记的) 数据。 对于输出特别有用。XML 支持网页。 XML 标记名会尽可能密切地符合数据存储区的列名。
使用 CDynamicAccessor 方法获取列信息。 使用该列信息在运行时动态创建访问器。
该列信息存储在由此类创建并管理的缓冲区中。 使用 GetXMLRowData,获取列信息。GetXMLColumnData 或按行获取列数据。
示例
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