OleDbEnumerator.GetEnumerator(Type) Metoda

Definice

Pomocí určitého enumerátoru OLE DB vrátí OleDbDataReader informace o aktuálně nainstalovaných zprostředkovatelů OLE DB bez nutnosti instance OleDbEnumerator třídy.

public:
 static System::Data::OleDb::OleDbDataReader ^ GetEnumerator(Type ^ type);
[System.Diagnostics.CodeAnalysis.RequiresDynamicCode("OleDbConnection is not AOT-compatible.")]
public static System.Data.OleDb.OleDbDataReader GetEnumerator(Type type);
public static System.Data.OleDb.OleDbDataReader GetEnumerator(Type type);
[<System.Diagnostics.CodeAnalysis.RequiresDynamicCode("OleDbConnection is not AOT-compatible.")>]
static member GetEnumerator : Type -> System.Data.OleDb.OleDbDataReader
static member GetEnumerator : Type -> System.Data.OleDb.OleDbDataReader
Public Shared Function GetEnumerator (type As Type) As OleDbDataReader

Parametry

type
Type

Nějaké Type.

Návraty

Obsahuje OleDbDataReader informace o požadovaných zprostředkovatelů OLE DB pomocí zadaného enumerátoru OLE DB.

Atributy

Výjimky

Poskytovatel nepodporuje ISourcesRowset.

V podkladovém poskytovateli došlo k výjimce.

Příklady

Následující konzolová aplikace používá komponentu MSDAENUM k načtení informací o všech zprostředkovatelích OLE DB a zobrazí informace v okně konzoly.

Imports System.Data  
Imports System.Data.OleDb  

Module Module1  

  Sub Main()  
    Dim enumerator As New OleDbEnumerator  
    Dim reader As OleDbDataReader = _  
     OleDbEnumerator.GetEnumerator(Type.GetTypeFromProgID("MSDAENUM"))  

    DisplayData(reader)  

    Console.WriteLine("Press any key to continue.")  
    Console.ReadKey()  
  End Sub  

  Private Sub DisplayData(ByVal reader As OleDbDataReader)  
    While reader.Read()  
      For i As Integer = 0 To reader.FieldCount - 1  
        Console.WriteLine("{0} = {1}", _  
         reader.GetName(i), reader.GetValue(i))  
      Next  
      Console.WriteLine("==================================")  
    End While  

  End Sub  
End Module  
using System;  
using System.Data;  
using System.Data.OleDb;  

class Program  
{  
 static void Main()  
 {  
   OleDbDataReader reader =   
     OleDbEnumerator.GetEnumerator(Type.GetTypeFromProgID("MSDAENUM"));  

   DisplayData(reader);  

   Console.WriteLine("Press any key to continue.");  
   Console.ReadKey();  
 }  

 static void DisplayData(OleDbDataReader reader)  
 {  
   while (reader.Read())  
   {  
     for (int i = 0; i < reader.FieldCount; i++)  
     {  
       Console.WriteLine("{0} = {1}",  
        reader.GetName(i), reader.GetValue(i));  
     }  
     Console.WriteLine("==================================");  
   }  
 }  
}  

Poznámky

Čtečka vrácená touto metodou obsahuje následující sloupce, z nichž všechny obsahují řetězce:

Řadový sloupcový Column Description
0 SOURCES_NAME Invariantní název nativního zdroje dat OLE DB nebo enumerátoru.
1 SOURCES_PARSENAME Název čitelný člověkem, který lze převést na moniker pomocí nativního rozhraní COM IParseDisplayName. Odpovídá SOURCES_PARSENAME sloupci vrácené nativní sadou řádků zdroje OLE DB.
2 SOURCES_DESCRIPTION Popis nativního zdroje dat OLE DB Odpovídá SOURCES_DESCRIPTION sloupci vrácené nativní sadou řádků zdroje OLE DB.
3 SOURCES_TYPE Jeden z následujících členů výčtu: Binder (0), DataSource_MDP (1), DataSource_TDP (2), Enumerator (3). Tyto hodnoty odpovídají hodnotám vráceným ve SOURCES_TYPE sloupci nativní sady řádků zdroje OLE DB.
4 SOURCES_ISPARENT Platí pouze pro enumerátory. Pokud trueoznačuje, že položka se vztahuje na stejný výčet, na kterém Byl volána GetSourcesRowset , což znamená, že je také zahrnuta do dílčího výčtu. Odpovídá SOURCES_ISPARENT sloupci nativní sady řádků zdrojů OLE DB.

OLE DB poskytuje několik komponent enumerátoru, včetně MSDAENUM, MSDASQL Enumerator, SQLNCLI Enumerator, SQLOLEDB Enumerator a dalších. Další informace o komponentách enumerátoru a jejich použití naleznete v referenční dokumentaci programátora OLE DB.

Platí pro