Vorgehensweise: Erstellen einer Suchtabelle mit der BindingSource-Komponente in Windows Forms
Eine Nachschlagetabelle ist eine Tabelle mit Daten, in der die Daten aus Datensätzen einer verknüpften Tabelle in einer Spalte dargestellt werden. In den folgenden Verfahren wird ein ComboBox-Steuerelement für die Anzeige des Felds mit der Fremdschlüsselbeziehung von der übergeordneten zur untergeordneten Tabelle verwendet.
Zur Visualisierung dieser beiden Tabellen und dieser Beziehung finden Sie hier ein Beispiel einer über- und untergeordneten Tabelle:
KundenTabelle (übergeordnete Tabelle)
CustomerID | CustomerName |
---|---|
712 | Paul Koch |
713 | Tamara Johnston |
OrdersTable (untergeordnete Tabelle)
OrderID | OrderDate | CustomerID |
---|---|---|
903 | Donnerstag, 12. Februar 2004 | 712 |
904 | 13. Februar 2004 | 713 |
In diesem Szenario speichert eine Tabelle, nämlich KundenTabelle, die tatsächlichen Daten, die Sie anzeigen und speichern möchten. Um aber Platz zu sparen, lässt die Tabelle Daten weg, was für Klarheit sorgt. Die andere Tabelle, BestellungenTabelle, enthält nur erscheinungsbezogene Daten darüber, welche Kunden-ID-Nummer welchem Bestelldatum und welcher Bestell-ID entspricht. Die Kundennamen werden nicht erwähnt.
Es sind vier wichtige Eigenschaften im ComboBox-Steuerelement für das Erstellen der Nachschlagetabelle festgelegt.
Die Eigenschaft DataSource enthält den Namen der Tabelle.
Die Eigenschaft DisplayMember enthält die Datenspalte dieser Tabelle, die für die Anzeige des Text-Steuerelements (der Name des Kunden) anzeigt werden soll.
Die Eigenschaft ValueMember enthält die Datenspalte der Tabelle mit den gespeicherten Informationen (der ID-Nummer und der übergeordneten Tabelle).
Die Eigenschaft SelectedValue liefert den Nachschlagewert für die untergeordnete Tabelle auf Grundlage von ValueMember.
Die Verfahren unten zeigen, wie Sie das Formular als Nachschlagetabelle gestalten und Daten mit den Steuerelementen darauf binden. Um die Verfahren erfolgreich durchführen zu können, benötigen Sie eine Datenquelle mit über- und untergeordneten Tabellen, die – wie bereits erwähnt – eine Fremdschlüsselbeziehung haben.
So erstellen Sie die Benutzeroberfläche
Ziehen Sie aus der Toolbox ein ComboBox-Steuerelement auf das Formular.
Dieses Steuerelement zeigt die Spalte aus der übergeordneten Tabelle an.
Ziehen Sie andere Steuerelemente zur Anzeige von Details aus der untergeordneten Tabelle. Das Format der Daten in der Tabelle bestimmt die Auswahl der Steuerelemente. Weitere Informationen finden Sie unter Windows Forms-Steuerelemente nach Funktion.
Ziehen Sie ein BindingNavigator-Steuerelement auf das Formular; damit können Sie die Daten in die untergeordnete Tabelle navigieren.
So verbinden Sie die Daten und binden diese an die Steuerelemente
Wählen Sie die ComboBox und klicken Sie das Symbol Smarttask, sodass das Dialogfeld Smarttask angezeigt wird.
Wählen Sie An Daten gebundene Elemente verwenden aus.
Klicken Sie auf den Pfeil neben dem Dropdownfeld Datenquelle. Wenn eine Datenquelle bereits für das Projekt oder Formular konfiguriert wurde, wird sie angezeigt; ansonsten führen Sie bitte die folgenden Schritte durch (In diesem Beispiel werden die Kunden- und Bestellungentabellen der Northwind-Beispieldatenbank verwendet, auf die in Klammern verwiesen wird).
Klicken Sie auf Projektdatenquelle hinzufügen, um die Daten zu verbinden und die Datenquelle zu erzeugen.
Klicken Sie auf der Startseite des Assistenten zum Konfigurieren von Datenquellen auf Weiter.
Wählen Sie auf der Seite Datenquellentyp auswählen die Option Datenbank aus.
Wählen Sie auf der Seite Wählen Sie Ihre Datenverbindung aus eine Datenverbindung aus der Liste verfügbar Verbindungen aus. Wenn die gewünschte Datenverbindung nicht verfügbar ist, wählen Sie Neue Verbindung aus, und legen Sie eine neue Verbindung an.
Klicken Sie auf Ja, Verbindung speichern unter, um die Verbindungszeichenfolge in der Anwendungskonfigurationsdatei zu speichern.
Wählen Sie die Datenbankobjekte, die in die Anwendung gebracht werden sollen. In diesem Fall wählen Sie eine übergeordnete und eine untergeordnete Tabelle (z. B. Kunden und Bestellungen) mit einer Fremdschlüsselbeziehung.
Ersetzen Sie den Standardnamen des Datasets falls gewünscht.
Klicken Sie auf Fertig stellen.
Wählen Sie im Dropdownfeld Member anzeigen den Spaltennamen aus (z.B. ContactName), der im Kombinationsfeld angezeigt werden soll.
Wählen Sie im Dropdownfeld Wertemember die Spalte (z.B. CustomerID) für das Durchführen des Nachschlagevorgangs in der untergeordneten Tabelle aus.
Navigieren Sie im Dropdownfeld Ausgewählter Wert zu Projektdatenquellen und dem eben erstellten Dataset mit den über- und untergeordneten Tabellen. Wählen Sie dieselbe Eigenschaft der untergeordneten Tabelle, die ein Wertemember der übergeordneten Tabelle ist (z. B. Orders.CustomerID). Das entsprechende Datenset BindingSource und die Tabelleadapterkomponenten werden erstellt und dem Formular hinzugefügt.
Binden Sie das Steuerelement BindingNavigator an die untergeordnete Tabelle BindingSource (z. B.
OrdersBindingSource
).Binden Sie die Steuerelement außer ComboBox und BindingNavigator an das Feld "Details" aus der BindingSource der untergeordneten Tabelle (z. B.
OrdersBindingSource
), die Sie anzeigen möchten.
Weitere Informationen
.NET Desktop feedback