Übersicht über das Füllen von Datasets und Abfragen von Daten
Aktualisiert: November 2007
Der TableAdapter stellt den typischen Mechanismus von Visual Studio zum Ausführen von Transact-SQL-Abfragen und zum Füllen von Datasets dar.
Sie können SQL-Anweisungen oder gespeicherte Prozeduren mithilfe von TableAdapters oder Befehlsobjekten (z. B. SqlCommand) an einer Datenquelle ausführen. Verwenden Sie TableAdapters, um Daten in Datasets zu laden, die mit Visual Studio-Entwurfstools erstellt wurden. Verwenden Sie Datenadapter, um Daten in Datasets zu laden, die programmgesteuert erstellt wurden. Wenn die Anwendung keine Datasets verwendet, führen Sie SQL-Anweisungen oder gespeicherte Prozeduren mithilfe von Befehlsobjekten direkt an einer Datenbank aus.
Themenbereich |
Weitere Informationen finden Sie unter |
---|---|
Füllen eines Datasets mittels TableAdapter |
|
TableAdapters |
|
Füllen eines Datasets mittels Datenadapter |
Auffüllen eines 'DataSet' durch einen 'DataAdapter' (ADO.NET) |
Füllen von Datasets
Wenn Sie ein Dataset mit einem Visual Studio-Entwurfszeittool (z. B. DataSet-Designer oder Assistent zum Konfigurieren von Datenquellen) erstellen, verwenden Sie zum Füllen einen TableAdapter. TableAdapter führen SQL-Anweisungen und gespeicherte Prozeduren aus.
Wenn Sie ein Dataset ohne Entwurfszeittools erstellen, müssen Sie die Daten mithilfe von Datenadaptern füllen und aktualisieren. (TableAdapter stellen keine tatsächlichen Klassen in .NET Framework 3,5 dar. Demnach sind sie für die Arbeit mit Datasets, die ohne Entwurfszeittools erstellt wurden, nicht geeignet.) Weitere Informationen zum Laden von Daten in Datasets mittels TableAdapters oder Datenadapter finden Sie unter Gewusst wie: Füllen eines Datasets mit Daten.
TableAdapter-Abfragen
Sie können TableAdapter-Abfragen ausführen, um Daten in Datasets zu füllen (d. h. Daten in die DataTables zu laden, die ein Dataset bilden). TableAdapter-Abfragen können mit dem Konfigurations-Assistent für TableAdapter-Abfragen im DataSet-Designer erstellt werden. TableAdapter-Abfragen treten als benannte Methoden für einen TableAdapter auf und werden durch Aufrufen der TableAdapter-Methode ausgeführt. Weitere Informationen zum Erstellen und Ausführen von TableAdapter-Abfragen finden Sie auf den folgenden Seiten:
Gewusst wie: Erstellen und Ausführen einer SQL-Anweisung, die Zeilen zurückgibt
Gewusst wie: Erstellen und Ausführen einer SQL-Anweisung, die einen einzelnen Wert zurückgibt
Gewusst wie: Erstellen und Ausführen einer SQL-Anweisung, die keinen Wert zurückgibt
Gewusst wie: Ausführen einer gespeicherten Prozedur, die Zeilen zurückgibt
Gewusst wie: Ausführen einer gespeicherten Prozedur, die einen einzelnen Wert zurückgibt
Gewusst wie: Ausführen einer gespeicherten Prozedur, die keinen Wert zurückgibt
Befehlsobjekte
Mit Befehlsobjekten haben Sie die Möglichkeit, SQL-Anweisungen und gespeicherte Prozeduren ohne DataSet, TableAdapter oder DataAdapter direkt an einer Datenbank auszuführen. (Der Begriff Befehlsobjekt bezieht sich auf den speziellen Befehl für den .NET Framework-Datenanbieter, der von der Anwendung verwendet wird. Wenn die Anwendung beispielsweise den .NET Framework-Datenanbieter für SQL Server verwendet, ist das Befehlsobjekt SqlCommand.)
Befehle werden konfiguriert, um Daten mithilfe von SQL-Anweisungen oder gespeicherten Prozeduren abzurufen. Dazu wird die CommandType-Eigenschaft des Datenbefehls auf einen der Werte in der CommandType-Enumeration festgelegt. Legen Sie CommandType zum Ausführen von SQL-Anweisungen auf Text fest, oder auf StoredProcedure, um gespeicherte Prozeduren auszuführen. Legen Sie die CommandText-Eigenschaft anschließend entweder auf eine SQL-Anweisung oder auf den Namen der gespeicherten Prozedur fest. Danach können Sie den Datenbefehl ausführen, indem Sie eine seiner Execute-Methoden aufrufen (ExecuteReader, ExecuteScalar, ExecuteNonQuery).
Jeder .NET Framework-Datenanbieter (ADO.NET) stellt ein Befehlsobjekt zur Verfügung, das für bestimmte Datenbanken optimiert wurde.
Datenbefehle ermöglichen Ihnen folgende Operationen in Ihrer Anwendung:
Ausführen von Select-Befehlen, die ein Ergebnis zurückgeben, das Sie direkt lesen können, statt es in das Dataset zu laden. Verwenden Sie einen Datenreader (OleDbDataReader-, SqlDataReader-, OdbcDataReader- oder OracleDataReader-Objekt), um die Ergebnisse zu lesen. Der Datenreader verhält sich wie ein schreibgeschützter Vorwärtscursor, an den Sie Steuerelemente binden können. Diese Strategie eignet sich zum Verringern der Speicherauslastung und zum sehr schnellen Laden von schreibgeschützten Daten.
Ausführen von DDL-Befehlen zum Erstellen, Bearbeiten und Entfernen von Tabellen, gespeicherten Prozeduren und anderen Datenbankstrukturen. (Für diese Aktionen benötigen Sie natürlich die entsprechenden Zugriffsrechte.)
Ausführen von Befehlen zum Abrufen von Kataloginformationen einer Datenbank.
Ausführen dynamischer SQL-Befehle zum Aktualisieren, Einfügen oder Löschen von Datasets anstelle des Aktualisierens von Tabellen im Dataset und des anschließenden Kopierens der Änderungen in die Datenbank.
Ausführen von Befehlen, die einen Skalarwert (d. h. einen einzelnen Wert) zurückgeben, z. B. die Ergebnisse einer Aggregatfunktion (SUM, COUNT, AVG usw.).
Ausführen von Befehlen, die Daten aus einer SQL Server-Datenbank (Version 7.0 oder höher) im XML-Format zurückgeben. Typisches Anwendungsbeispiel: Ausführen einer Anfrage und Abrufen der Daten im XML-Format, Durchführen einer XSLT-Transformation (zum Konvertieren ins HTML-Format) und Senden der Ergebnisse an einen Browser.
Die Eigenschaften eines Befehls enthalten alle erforderlichen Informationen, die für die Ausführung eines Befehls an einer Datenbank erforderlich sind. Dies umfasst Folgendes:
Eine Verbindung Der Befehl verweist auf eine Verbindung, über die er mit der Datenbank kommuniziert.
Der Name oder Text eines Befehls Der Befehl enthält den eigentlichen Text einer SQL-Anweisung oder den Namen einer auszuführenden gespeicherten Prozedur.
Parameter Möglicherweise müssen Sie Parameterwerte zusammen mit dem Befehl übergeben (Eingabeparameter). Der Befehl kann auch Werte in Form eines Rückgabewerts oder in Form von Ausgabeparameterwerten zurückgeben. Zu jedem Befehl gehört eine bestimmte Anzahl von Parametern, die Sie einzeln festlegen oder lesen können, um Werte zu übergeben oder zu empfangen. Weitere Informationen finden Sie unter Gewusst wie: Festlegen und Abrufen von Parametern für Befehlsobjekte.
Befehle werden mithilfe einer Methode ausgeführt, die sich für die erwarteten Ergebnisse eignet. Wenn Sie z. B. Zeilen erwarten, rufen Sie die ExecuteReader-Methode des Befehls auf, die Datensätze in einem Datenreader zurückgibt. Wenn Sie einen UPDATE-Befehl, einen INSERT-Befehl oder einen DELETE-Befehl ausführen, rufen Sie die ExecuteNonQuery-Methode des Befehls auf, die einen Wert mit der Anzahl der betroffenen Zeilen zurückgibt. Wenn Sie eine Aggregatfunktion (z. B. Rückgabe der Anzahl an Bestellungen eines Kunden) ausführen, rufen Sie die ExecuteScalar-Methode auf.
Mehrere Resultsets
Befehlsobjekte werden z. B. verwendet, wenn eine einzelne Datentabelle (eine Gruppe von Zeilen) zurückgegeben werden soll. Allerdings können Befehle Prozeduren ausführen, die mehrere Resultsets zurückgeben. Dies kann sich auf verschiedene Arten vollziehen. Eine Möglichkeit besteht darin, dass der Befehl auf eine gespeicherte Prozedur verweist, die mehrere Resultsets zurückgibt. Alternativ dazu kann der Befehl auch zwei (oder mehr) Anweisungen oder Namen von gespeicherten Prozeduren enthalten. In diesem Fall werden die Anweisungen oder Prozeduren nacheinander ausgeführt und mit einem einzelnen Aufruf mehrere Resultsets zurückgegeben.
Wenn Sie für einen Befehl mehrere Anweisungen oder Prozeduren festlegen, müssen diese alle vom selben Typ sein. Sie können z. B. aufeinander folgende SQL-Anweisungen oder aufeinander folgende gespeicherte Prozeduren ausführen. Sie können jedoch nicht Aufrufe für gespeicherte Prozeduren und SQL-Anweisungen im selben Befehl verwenden. Weitere Informationen finden Sie unter Abrufen von Daten mit einem 'DataReader' (ADO.NET).
Hinweis: |
---|
Bei Oracle-Datenbanken unterstützt der .NET Framework-Datenanbieter für Oracle keine als Batch verarbeitete SQL-Anweisungen. Er ermöglicht jedoch die Verwendung mehrerer REF CURSOR-Ausgabeparameter, um ein Dataset in einer jeweils eigenen Datentabelle auszufüllen. Sie müssen die Parameter definieren, diese als Ausgabeparameter markieren und angeben, dass sie REF CURSOR-Datentypen sind. Beachten Sie, dass Sie die Update-Methode nicht verwenden können, wenn das OracleDataAdapter-Objekt von REF CURSOR-Parametern in eine gespeicherte Prozedur gefüllt wird. Dies liegt daran, dass Oracle-Datenbanken nicht die Informationen bereitstellen, die beim Ausführen der SQL-Anweisung erforderlich sind, um den Tabellennamen und die Spaltennamen festzustellen. |
Sicherheit
Wenn Datenbefehle in Verbindung mit einer CommandType-Eigenschaft verwendet werden, die auf Text festgelegt ist, müssen Sie die von einem Client gesendeten Informationen sorgfältig prüfen, bevor Sie sie an die Datenbank übergeben. Böswillige Benutzer könnten versuchen, veränderte oder zusätzliche SQL-Anweisungen zu senden (einzufügen), um unautorisierten Zugriff zu erhalten oder die Datenbank zu beschädigen. Bevor Sie Benutzereingaben an eine Datenbank übergeben, müssen Sie immer die Zulässigkeit der Informationen überprüfen. Es wird empfohlen, möglichst immer parametrisierte Abfragen oder gespeicherte Prozeduren zu verwenden.
Siehe auch
Weitere Ressourcen
Erste Schritte mit dem Datenzugriff
Herstellen von Datenverbindungen in Visual Studio
Vorbereiten der Anwendung auf den Empfang von Daten
Abrufen von Daten für die Anwendung
Anzeigen von Daten in Formularen in Windows-Anwendungen