Procedura dettagliata: Creazione di un modulo Master-Details usando due controlli DataGridView di Windows Forms
Uno degli scenari più comuni per l'uso del DataGridView controllo è il modulo master/dettaglio , in cui viene visualizzata una relazione padre/figlio tra due tabelle di database. Se si selezionano righe nella tabella master, la tabella dei dettagli viene aggiornata con i dati figlio corrispondenti.
L'implementazione di un modulo master/dettagli è semplice tramite l'interazione tra il DataGridView controllo e il BindingSource componente. In questa procedura dettagliata verrà compilato il modulo usando due DataGridView controlli e due BindingSource componenti. Nel modulo verranno visualizzate due tabelle correlate nel database di esempio Northwind SQL Server: Customers
e Orders
. Al termine, si avrà un modulo che mostra tutti i clienti nel database nel master DataGridView e tutti gli ordini per il cliente selezionato nel dettaglio DataGridView.
Per copiare il codice in questo argomento come singolo elenco, vedere Procedura: Creare un modulo master/dettaglio usando due controlli DataGridView Windows Forms.
Prerequisiti
Per completare questo scenario, saranno necessari gli elementi seguenti:
- Accesso a un server con northwind SQL Server database di esempio.
Creazione del modulo
Per creare un modulo master/dettaglio
Creare una classe che deriva da Form e contiene due DataGridView controlli e due BindingSource componenti. Il codice seguente fornisce l'inizializzazione del modulo di base e include un
Main
metodo . Se si usa la finestra di progettazione di Visual Studio per creare il modulo, è possibile usare il codice generato dalla finestra di progettazione anziché questo codice, ma assicurarsi di usare i nomi mostrati nelle dichiarazioni di variabile qui.using System; using System.Data; using System.Data.SqlClient; using System.Windows.Forms; public class Form1 : System.Windows.Forms.Form { private DataGridView masterDataGridView = new DataGridView(); private BindingSource masterBindingSource = new BindingSource(); private DataGridView detailsDataGridView = new DataGridView(); private BindingSource detailsBindingSource = new BindingSource(); [STAThreadAttribute()] public static void Main() { Application.Run(new Form1()); } // Initializes the form. public Form1() { masterDataGridView.Dock = DockStyle.Fill; detailsDataGridView.Dock = DockStyle.Fill; SplitContainer splitContainer1 = new SplitContainer(); splitContainer1.Dock = DockStyle.Fill; splitContainer1.Orientation = Orientation.Horizontal; splitContainer1.Panel1.Controls.Add(masterDataGridView); splitContainer1.Panel2.Controls.Add(detailsDataGridView); this.Controls.Add(splitContainer1); this.Load += new System.EventHandler(Form1_Load); this.Text = "DataGridView master/detail demo"; }
Imports System.Data Imports System.Data.SqlClient Imports System.Windows.Forms Public Class Form1 Inherits System.Windows.Forms.Form Private masterDataGridView As New DataGridView() Private masterBindingSource As New BindingSource() Private detailsDataGridView As New DataGridView() Private detailsBindingSource As New BindingSource() <STAThreadAttribute()> _ Public Shared Sub Main() Application.Run(New Form1()) End Sub ' Initializes the form. Public Sub New() masterDataGridView.Dock = DockStyle.Fill detailsDataGridView.Dock = DockStyle.Fill Dim splitContainer1 As New SplitContainer() splitContainer1.Dock = DockStyle.Fill splitContainer1.Orientation = Orientation.Horizontal splitContainer1.Panel1.Controls.Add(masterDataGridView) splitContainer1.Panel2.Controls.Add(detailsDataGridView) Me.Controls.Add(splitContainer1) Me.Text = "DataGridView master/detail demo" End Sub
}
End Class
Implementare un metodo nella definizione della classe del modulo per gestire i dettagli della connessione al database. In questo esempio viene utilizzato un
GetData
metodo che popola un DataSet oggetto , aggiunge un DataRelation oggetto al set di dati e associa i BindingSource componenti. Assicurarsi di impostare la variabileconnectionString
su un valore appropriato per il database.Importante
L'archiviazione delle informazioni riservate, ad esempio la password, nella stringa di connessione può avere implicazioni sulla sicurezza dell'applicazione. L'autenticazione di Windows, detta anche sicurezza integrata, consente di controllare l'accesso a un database in modo più sicuro. Per altre informazioni, vedere Protezione delle informazioni di connessione.
private void GetData() { try { // Specify a connection string. Replace the given value with a // valid connection string for a Northwind SQL Server sample // database accessible to your system. String connectionString = "Integrated Security=SSPI;Persist Security Info=False;" + "Initial Catalog=Northwind;Data Source=localhost"; SqlConnection connection = new SqlConnection(connectionString); // Create a DataSet. DataSet data = new DataSet(); data.Locale = System.Globalization.CultureInfo.InvariantCulture; // Add data from the Customers table to the DataSet. SqlDataAdapter masterDataAdapter = new SqlDataAdapter("select * from Customers", connection); masterDataAdapter.Fill(data, "Customers"); // Add data from the Orders table to the DataSet. SqlDataAdapter detailsDataAdapter = new SqlDataAdapter("select * from Orders", connection); detailsDataAdapter.Fill(data, "Orders"); // Establish a relationship between the two tables. DataRelation relation = new DataRelation("CustomersOrders", data.Tables["Customers"].Columns["CustomerID"], data.Tables["Orders"].Columns["CustomerID"]); data.Relations.Add(relation); // Bind the master data connector to the Customers table. masterBindingSource.DataSource = data; masterBindingSource.DataMember = "Customers"; // Bind the details data connector to the master data connector, // using the DataRelation name to filter the information in the // details table based on the current row in the master table. detailsBindingSource.DataSource = masterBindingSource; detailsBindingSource.DataMember = "CustomersOrders"; } catch (SqlException) { MessageBox.Show("To run this example, replace the value of the " + "connectionString variable with a connection string that is " + "valid for your system."); } }
Private Sub GetData() Try ' Specify a connection string. Replace the given value with a ' valid connection string for a Northwind SQL Server sample ' database accessible to your system. Dim connectionString As String = _ "Integrated Security=SSPI;Persist Security Info=False;" & _ "Initial Catalog=Northwind;Data Source=localhost" Dim connection As New SqlConnection(connectionString) ' Create a DataSet. Dim data As New DataSet() data.Locale = System.Globalization.CultureInfo.InvariantCulture ' Add data from the Customers table to the DataSet. Dim masterDataAdapter As _ New SqlDataAdapter("select * from Customers", connection) masterDataAdapter.Fill(data, "Customers") ' Add data from the Orders table to the DataSet. Dim detailsDataAdapter As _ New SqlDataAdapter("select * from Orders", connection) detailsDataAdapter.Fill(data, "Orders") ' Establish a relationship between the two tables. Dim relation As New DataRelation("CustomersOrders", _ data.Tables("Customers").Columns("CustomerID"), _ data.Tables("Orders").Columns("CustomerID")) data.Relations.Add(relation) ' Bind the master data connector to the Customers table. masterBindingSource.DataSource = data masterBindingSource.DataMember = "Customers" ' Bind the details data connector to the master data connector, ' using the DataRelation name to filter the information in the ' details table based on the current row in the master table. detailsBindingSource.DataSource = masterBindingSource detailsBindingSource.DataMember = "CustomersOrders" Catch ex As SqlException MessageBox.Show("To run this example, replace the value of the " & _ "connectionString variable with a connection string that is " & _ "valid for your system.") End Try End Sub
Implementare un gestore per l'evento del Load modulo che associa i DataGridView controlli ai BindingSource componenti e chiama il
GetData
metodo . L'esempio seguente include il codice che ridimensiona le DataGridView colonne in base ai dati visualizzati.private void Form1_Load(object sender, System.EventArgs e) { // Bind the DataGridView controls to the BindingSource // components and load the data from the database. masterDataGridView.DataSource = masterBindingSource; detailsDataGridView.DataSource = detailsBindingSource; GetData(); // Resize the master DataGridView columns to fit the newly loaded data. masterDataGridView.AutoResizeColumns(); // Configure the details DataGridView so that its columns automatically // adjust their widths when the data changes. detailsDataGridView.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells; }
Private Sub Form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) _ Handles Me.Load ' Bind the DataGridView controls to the BindingSource ' components and load the data from the database. masterDataGridView.DataSource = masterBindingSource detailsDataGridView.DataSource = detailsBindingSource GetData() ' Resize the master DataGridView columns to fit the newly loaded data. masterDataGridView.AutoResizeColumns() ' Configure the details DataGridView so that its columns automatically ' adjust their widths when the data changes. detailsDataGridView.AutoSizeColumnsMode = _ DataGridViewAutoSizeColumnsMode.AllCells End Sub
Test dell'applicazione
È ora possibile testare il modulo per assicurarsi che si comporti come previsto.
Per testare il modulo
Compilare l'applicazione ed eseguirla.
Verranno visualizzati due DataGridView controlli, uno sopra l'altro. In alto sono i clienti della tabella Northwind
Customers
e nella parte inferiore corrispondeOrders
al cliente selezionato. Quando si selezionano righe diverse nell'angolo superiore DataGridView, il contenuto della modifica inferiore DataGridView viene modificato di conseguenza.
Passaggi successivi
Questa applicazione offre una conoscenza di base delle DataGridView funzionalità del controllo. È possibile personalizzare l'aspetto e il comportamento del DataGridView controllo in diversi modi:
Modificare gli stili di bordo e intestazione. Per altre informazioni, vedere Procedura: Modificare gli stili bordo e griglia nel controllo DataGridView Windows Forms.
Abilitare o limitare l'input dell'utente al DataGridView controllo. Per altre informazioni, vedere Procedura: Impedire l'aggiunta e l'eliminazione di righe nel controllo DataGridView Windows Forms e Procedura: Impostare colonne Read-Only nel controllo DataGridView Windows Forms.
Convalidare l'input dell'utente per il DataGridView controllo . Per altre informazioni, vedere Procedura dettagliata: Convalida dei dati nel controllo DataGridView Windows Forms.
Gestire set di dati di grandi dimensioni usando la modalità virtuale. Per altre informazioni, vedere Procedura dettagliata: Implementazione della modalità virtuale nel controllo DataGridView Windows Forms.
Personalizzare l'aspetto delle celle. Per altre informazioni, vedere Procedura: Personalizzare l'aspetto delle celle nel controllo DataGridView Windows Forms e Procedura: Impostare gli stili di cella predefiniti per il controllo DataGridView Windows Forms.