Použití dynamických přístupových objektů
Dynamicky přistupující objekty povolují přístup ke zdroji dat, když nemáte žádné znalosti o schématu databáze (základní strukturu).Knihovna šablon technologie OLE DB obsahuje několik tříd, které Vám to pomohou provést.
Ukázka DynamicConsumer znázorňuje, jak používat třídy dynamicky přistupujícího objektu k získání informací o sloupci a dynamicky vytvářet přístupové objekty.
Použití CDynamicAccessor
CDynamicAccessor vám umožní přístup ke zdroji dat, když nemáte žádné znalosti o schématu databáze (základní databázovou strukturu).Metody CDynamicAccessor získávají informace o sloupci jako jsou názvy sloupců, počet a datový typ. Tyto informace sloupce můžete použít k vytvoření dynamicky přistupujícího objektu za běhu.Informace sloupce jsou uloženy ve vyrovnávací paměti, která je vytvořena a spravována touto třídou.Data získáte z vyrovnávací paměti, pomocí metody GetValue.
Příklad
Kód
// Using_Dynamic_Accessors.cpp
// compile with: /c /EHsc
#include <stdio.h>
#include <objbase.h>
#include <atldbcli.h>
int main( int argc, char* argv[] )
{
HRESULT hr = CoInitialize( NULL );
CDataSource ds;
CSession ss;
CTable<CDynamicAccessor> rs;
// The following is an example initialization string:
hr = ds.OpenFromInitializationString(L"Provider=SQLOLEDB.1;"
L"Integrated Security=SSPI;Persist Security Info=False;"
L"Initial Catalog=Loginname;Data Source=your_data_source;"
L"Use Procedure for Prepare=1;Auto Translate=True;"
L"Packet Size=4096;Workstation ID=LOGINNAME01;"
L"Use Encryption for Data=False;"
L"Tag with column collation when possible=False");
hr = ss.Open( ds );
hr = rs.Open( ss, "Shippers" );
hr = rs.MoveFirst( );
while( SUCCEEDED( hr ) && hr != DB_S_ENDOFROWSET )
{
for( size_t i = 1; i <= rs.GetColumnCount( ); i++ )
{
DBTYPE type;
rs.GetColumnType( i, &type );
printf_s( "Column %d [%S] is of type %d\n",
i, rs.GetColumnName( i ), type );
switch( type )
{
case DBTYPE_WSTR:
printf_s( "value is %S\n",
(WCHAR*)rs.GetValue( i ) );
break;
case DBTYPE_STR:
printf_s( "value is %s\n",
(CHAR*)rs.GetValue( i ) );
default:
printf_s( "value is %d\n",
*(long*)rs.GetValue( i ) );
}
}
hr = rs.MoveNext( );
}
rs.Close();
ss.Close();
ds.Close();
CoUninitialize();
return 0;
}
Použití CDynamicStringAccessor
CDynamicStringAccessor pracuje jako CDynamicAccessor, s výjimkou jednoho důležitého způsobu.Zatímco CDynamicAccessor požaduje data v nativním formátu, vykazována zprostředkovatelem, CDynamicStringAccessor požaduje, aby zprostředkovatel načítal všechna data z úložiště dat jako řetězcová data. To je užitečné zejména pro jednoduché úkoly, které nevyžadují výpočet hodnot v úložišti dat, jako je zobrazení nebo tisk obsahu úložiště dat.
Použití metod CDynamicStringAccessor k získání informací o sloupci. Tyto informace sloupce můžete použít k vytvoření dynamicky přistupujícího objektu za běhu.Informace sloupce jsou uloženy ve vyrovnávací paměti a spravovány touto třídou.Data získáte z vyrovnávací paměti, pomocí CDynamicStringAccessor::GetString nebo je uložíte do vyrovnávací paměti, pomocí CDynamicStringAccessor::SetString.
Příklad
Kód
// Using_Dynamic_Accessors_b.cpp
// compile with: /c /EHsc
#include <stdio.h>
#include <objbase.h>
#include <atldbcli.h>
int main( int argc, char* argv[] )
{
HRESULT hr = CoInitialize( NULL );
if (hr != S_OK)
{
exit (-1);
}
CDataSource ds;
CSession ss;
CTable<CDynamicStringAccessor> rs;
// The following is an example initialization string:
hr = ds.OpenFromInitializationString(L"Provider=SQLOLEDB.1;"
L"Integrated Security=SSPI;Persist Security Info=False;"
L"Initial Catalog=Loginname;Data Source=your_data_source;"
L"Use Procedure for Prepare=1;Auto Translate=True;"
L"Packet Size=4096;Workstation ID=LOGINNAME01;"
L"Use Encryption for Data=False;"
L"Tag with column collation when possible=False");
hr = ss.Open( ds );
hr = rs.Open( ss, "Shippers" );
hr = rs.MoveFirst( );
while( SUCCEEDED( hr ) && hr != DB_S_ENDOFROWSET )
{
for( size_t i = 1; i <= rs.GetColumnCount( ); i++ )
{
printf_s( "column %d value is %s\n",
i, rs.GetString( i ) );
}
hr = rs.MoveNext( );
}
rs.Close();
ss.Close();
ds.Close();
CoUninitialize();
return 0;
}
Použití CDynamicParameterAccessor
CDynamicParameterAccessor je podobná CDynamicAccessor s tou výjimkou, že CDynamicParameterAccessor získává informace o parametrech, které mají být nastaveny voláním rozhraní ICommandWithParameters.Zprostředkovatel musí podporovat ICommandWithParameters pro příjemce k použití této třídy.
Informace o parametrech jsou uloženy ve vyrovnávací paměti a spravovány touto třídou.Data parametru získáte z vyrovnávací paměti, pomocí CDynamicParameterAccessor::GetParam a CDynamicParameterAccessor::GetParamType.
Příklad demonstrující použití této třídy spuštění serveru SQL Server uložené procedury a získání hodnoty výstupního parametru naleznete v článku znalostní báze Knowledge Base Q058860, "postupy: spustit uložené procedury pomocí CDynamicParameterAccessor." Články znalostní báze jsou k dispozici v knihovně MSDN dokumentaci sady Visual Studio nebo na https://support.microsoft.com.
Viz také
Referenční dokumentace
CDynamicStringAccessor – třída
CDynamicParameterAccessor – třída