Condividi tramite


Creare un controllo utente di .NET Framework Windows Form che supporta il data binding complesso con ADO.NET

Nota

I set di dati e le classi correlate sono tecnologie .NET Framework legacy dei primi anni '2000 che consentono alle applicazioni di lavorare con i dati in memoria mentre le applicazioni vengono disconnesse dal database. Sono particolarmente utili per le applicazioni che consentono agli utenti di modificare i dati e rendere persistenti le modifiche apportate al database. Anche se i set di dati hanno dimostrato di essere una tecnologia molto efficace, è consigliabile che le nuove applicazioni .NET usino Entity Framework Core. Entity Framework offre un modo più naturale per usare i dati tabulari come modelli a oggetti e ha un'interfaccia di programmazione più semplice.

Quando si visualizzano dati nei moduli nelle applicazioni Windows, è possibile scegliere i controlli esistenti dalla casella degli strumenti. In alternativa, è possibile creare controlli personalizzati se l'applicazione richiede funzionalità non disponibili nei controlli standard. In questa procedura dettagliata è illustrato come creare un controllo che implementa ComplexBindingPropertiesAttribute. I controlli che implementano ComplexBindingPropertiesAttribute contengono DataSource e la proprietà DataMember che può essere associata ai dati. Tali controlli sono simili a DataGridView o ListBox.

Per altre informazioni sulla creazione di controlli, vedere Sviluppo di controlli Windows Form in fase di progettazione.

Quando si creano controlli da usare negli scenari di data binding, è necessario implementare uno degli attributi di data binding seguenti:

Utilizzo degli attributi di data binding
Implementare DefaultBindingPropertyAttribute su controlli semplici, ad esempio TextBox, che visualizzano una singola colonna, o proprietà, di dati. Per altre informazioni, vedere Creare un controllo utente Windows Form che supporta il data binding semplice.
Implementare ComplexBindingPropertiesAttribute su controlli, ad esempio DataGridView, che visualizzano elenchi, o tabelle, di dati. Il processo è descritto in questa pagina di procedura dettagliata.
Implementare LookupBindingPropertiesAttribute su controlli, ad esempio ComboBox, che visualizzano elenchi, o tabelle, di dati ma che devono anche presentare una singola colonna o proprietà. Per altre informazioni, vedere Creare un controllo utente Windows Form che supporta il data binding di ricerca.

Questa procedura dettagliata crea un controllo complesso che visualizza righe di dati da una tabella. In questo esempio viene usata la tabella Customers del database di esempio Northwind. Il controllo utente complesso visualizzerà la tabella dei clienti in un oggetto DataGridView nel controllo personalizzato.

Durante questa procedura dettagliata si apprenderà come:

  • Aggiungere un nuovo controllo utente al progetto.

  • Progettare visivamente il controllo utente.

  • Implementare l'attributo ComplexBindingProperty.

  • Creare un set di dati con la Configurazione guidata origine dati.

  • Impostare la tabella Customers nella finestra Origini dati per usare il nuovo controllo complesso.

  • Aggiungere il nuovo controllo trascinandolo dalla finestra Origini dati in Form1.

Prerequisiti

Per completare questa esercitazione, sono necessari i carichi di lavoro sviluppo per desktop .NET e Archiviazione dati ed elaborazione dei dati installati in Visual Studio. Per installarli, aprire Programma di installazione di Visual Studio e scegliere Modifica (o Altro>modifica) accanto alla versione di Visual Studio da modificare. Vedere Modificare Visual Studio.

Questa procedura dettagliata usa sql Server Express Local DB e il database di esempio Northwind.

  1. Se SQL Server Express Local DB non è disponibile, installarlo dalla pagina di download di SQL Server Express o tramite il Programma di installazione di Visual Studio. Nella Programma di installazione di Visual Studio è possibile installare SQL Server Express Local DB come parte del carico di lavoro Archiviazione ed elaborazione dei dati o come singolo componente.

  2. Installare il database di esempio Northwind seguendo questa procedura:

    1. In Visual Studio aprire la finestra Esplora oggetti di SQL Server. SQL Server Esplora oggetti viene installato come parte del carico di lavoro Archiviazione ed elaborazione dei dati nel Programma di installazione di Visual Studio. Espandere il nodo SQL Server. Fare clic con il pulsante destro del mouse sull'istanza di Local DB e scegliere Nuova query.

      Verrà visualizzata una finestra dell'editor di query.

    2. Copiare lo script Transact-SQL Northwind negli Appunti. Questo script T-SQL crea il database Northwind da zero e lo popola con i dati.

    3. Incollare lo script T-SQL nell'editor di query e quindi scegliere il pulsante Esegui .

      Dopo un breve periodo di tempo, la query termina l'esecuzione e viene creato il database Northwind.

Creare un progetto di app Windows Form

Il primo passaggio consiste nel creare un progetto app Windows Form per C# o Visual Basic. Assegnare al progetto il nome ComplexControlWalkthrough.

Aggiungere un controllo utente al progetto

Poiché questa procedura dettagliata crea un controllo associabile a dati complesso da un controllo utente, aggiungere un elemento Controllo utente al progetto:

  1. Scegliere Aggiungi controllo utente dal menu Progetto.

  2. Digitare ComplexDataGridView nell'area Nome e quindi fare clic su Aggiungi.

    Il controllo ComplexDataGridView viene aggiunto a Esplora soluzioni e si apre nella finestra di progettazione.

Progettare il controllo ComplexDataGridView

Per aggiungere un oggetto al controllo utente, trascinare un DataGridViewDataGridView oggetto dalla casella degli strumenti nell'area di progettazione del controllo utente.

Aggiungere l'attributo di data binding richiesto

Per controlli semplici che supportano il data binding, è possibile implementare l'attributo ComplexBindingPropertiesAttribute:

  1. Passare al controllo ComplexDataGridView per la visualizzazione del codice. Scegliere Codice dal menu Visualizza.

  2. Sostituire il codice nel controllo ComplexDataGridView con la stringa seguente:

    using System.Windows.Forms;
    
    namespace CS
    {
        [System.ComponentModel.ComplexBindingProperties("DataSource", "DataMember")]
        public partial class ComplexDataGridView : UserControl
        {
            public object DataSource
            {
                get{ return dataGridView1.DataSource; }
                set{ dataGridView1.DataSource = value; }
            }
    
            public string DataMember
            {
                get{ return dataGridView1.DataMember; }
                set{ dataGridView1.DataMember = value; }
            }
    
            public ComplexDataGridView()
            {
                InitializeComponent();
            }
        }
    }
    
  3. Scegliere Compila soluzione dal menu Compila.

Creare un'origine dati dal database

Usare la configurazione guidata origine dati per creare un'origine dati basata sulla Customers tabella nel database di esempio Northwind:

  1. Per aprire la finestra Origini dati, scegliere Mostra origini dati dal menu Dati.

  2. Nella finestra Origini dati selezionare Aggiungi nuova origine dati per avviare la Configurazione guidata origine dati.

  3. Selezionare Database nella pagina Scegliere un tipo di origine dati e scegliere Avanti.

  4. Nella pagina Seleziona connessione dati eseguire una delle operazioni seguenti:

    • Se nell'elenco a discesa è disponibile una connessione dati al database di esempio Northwind, selezionarla.

    • Selezionare Nuova connessione per aprire la finestra di dialogo Aggiungi/Modifica connessione.

  5. Se il database in uso richiede una password, selezionare l'opzione che consente di includere dati sensibili, quindi scegliere Avanti.

  6. Nella pagina Salva stringa di connessione nel file di configurazione dell'applicazione fare clic su Avanti.

  7. Espandere il nodo Tables nella pagina Seleziona oggetti di database.

  8. Selezionare la tabella Customers, quindi fare clic su Fine.

    L'oggetto NorthwindDataSet viene aggiunto al progetto e la tabella Customers viene visualizzata nella finestra Origini dati.

Impostare la tabella Customers per usare il controllo ComplexDataGridView

Nella finestra Origini dati è possibile impostare il controllo da creare prima di trascinare elementi nel form:

  1. Aprire Form1 nella finestra di progettazione.

  2. Espandere il nodo Customers nella finestra Origini dati.

  3. Fare clic sulla freccia dell'elenco a discesa nel nodo Clienti e scegliere Personalizza.

  4. Selezionare ComplexDataGridView nell'elenco Controlli associati nella finestra di dialogo Personalizzazione dell'interfaccia utente dati.

  5. Fare clic sulla freccia dell'elenco a discesa nella Customers tabella e scegliere ComplexDataGridView dall'elenco dei controlli.

Aggiungere controlli al modulo

È possibile creare i controlli associati a dati trascinando elementi dalla finestra Origini dati nel form. Trascinare il nodo Customers principale dalla finestra Origini dati al form. Verificare che il controllo ComplexDataGridView venga usato per visualizzare i dati della tabella.

Eseguire l'applicazione

Premere F5 per eseguire l'applicazione.

Passaggi successivi

A seconda dei requisiti dell'applicazione, è possibile eseguire diversi passaggi dopo la creazione di un controllo che supporta l'associazione dati. Ecco alcuni dei passaggi più comuni: