IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Windows Forms Discussion :

Intérèt du BindingSource


Sujet :

Windows Forms

  1. #1
    Membre expert

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2007
    Messages
    3 410
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 410
    Points : 3 038
    Points
    3 038
    Par défaut Intérèt du BindingSource
    Bonjour,

    Suite à un précédent poste, j'ai compris un peu mieux le fonctionnement des Dataset, DataAdapter, SQLCommandBuilder et j'en passe ...

    Mon code est le suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
            private void button1_Click(object sender, EventArgs e)
            {
                try
                {
     
                    sqlConnection1.ConnectionString = "Data Source=.\\SQLEXPRESS;Initial Catalog=\"MABASE\";Integrated Security=True;Connect Timeout=30;User Instance=False;Context Connection=False";
     
                    sdaPhotos = new SqlDataAdapter("SELECT * FROM PHOTOS", sqlConnection1);
                    monDataSet.Tables.Add("Photos");
                    sdaPhotos.Fill(monDataSet.Tables["Photos"]);
     
                    sdaProduits = new SqlDataAdapter("SELECT * FROM PRODUITS", sqlConnection1);
                    monDataSet.Tables.Add("Produits");
                    sdaProduits.Fill(monDataSet.Tables["Produits"]);
     
                    sdaProduits.TableMappings.Add("Table", "Photos");
                    sdaPhotos.TableMappings.Add("Table", "Produits");
     
                    SqlCommandBuilder builderPhotos = new SqlCommandBuilder();
                    SqlCommandBuilder builderProduits = new SqlCommandBuilder();
     
                    builderPhotos.DataAdapter = sdaPhotos;
                    builderProduits.DataAdapter = sdaProduits;
     
                    dataGridView1.DataSource = monDataSet.Tables[0];
                    dataGridView2.DataSource = monDataSet.Tables[1];
     
                }
                catch (Exception exc)
                {
                    MessageBox.Show(exc.Message);
                }
     
            }
     
            private void btnValider_Click(object sender, EventArgs e)
            {
                sdaPhotos.Update(monDataSet.Tables["Photos"]);
                sdaProduits.Update(monDataSet.Tables["Produits"]);
            }
    Avec ce code, je visualise mes données et je peux modifier les données sous-jacentes par la commande update.

    Et là me vient une question :
    Quand j'utilise les assistants de VS, je retrouve sur mon formulaire un BindingSource.
    Avec mon code, sans BindingSource, ça fonctionne tout aussi bien.

    Donc, à quoi sert le BindingSource créé automatiquement par VS ?


    Papy !

  2. #2
    Membre chevronné Avatar de LooserBoy
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2005
    Messages
    1 085
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2005
    Messages : 1 085
    Points : 1 976
    Points
    1 976
    Par défaut
    En .net, tu as la possibilité de gérer de nombreuses choses dont les Dataset, BindingSource, etc de manière graphique via le designer ou manuellement par code.
    Le designer ajoute certains éléments en fonction d'autres éléments pour "aider" à la réalisation.
    Dans ton cas, compte tenu du fait que tu geres les choses par code, la bindingsource n'est pas utile.
    Vu sur un paquet de cigarettes: "Fumer peut entrainer une mort lente et douloureuse"
    - Vivre aussi... Ce n'est pas forcément moins douloureux et c'est même beaucoup plus lent...

  3. #3
    Membre émérite Avatar de Guulh
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2 160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2 160
    Points : 2 925
    Points
    2 925
    Par défaut
    Ca permet surtout de dissocier encore plus métier et affichage. Le bindingSource peut avoir quasiment n'importe quoi en source (DataTable, IList, etc.), et c'est pas plus mal de lui déléguer toute cette partie de binding de façon à ne présenter aux DataGridViews que des BindingSource.
    J'ajoute que si deux grilles doivent avoir la même source de donnée sans pour autant devoir être synchronisées (i.e. la sélection d'un élément dans l'une sélectionne automatiquement ce même élément dans l'autre), deux bindingsource ayant eux même la même source sont nécessaires.
    ಠ_ಠ

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Le BindingSource s'intercale entre les objets métier et la couche de présentation, c'est donc un contrôleur au sens Modèle Vue Contrôleur.

    Le design Pattern implémenté par Microsoft diffère un poil de la définition Java mais il est bien pratique par qu'il permet par exemple (si on a bien tout codé) de savoir si il y a eu ou non édition.

  5. #5
    Membre expert

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2007
    Messages
    3 410
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 410
    Points : 3 038
    Points
    3 038
    Par défaut
    Merci de vos "remarques" :-)

    Je comprends un peu mieux le sens de cette classe.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Mais quel est l'intérêt de XML ?
    Par darkbauer dans le forum XML/XSL et SOAP
    Réponses: 7
    Dernier message: 01/06/2004, 18h03
  2. [TDataModule] Intérêt de séparer les accès aux données?
    Par Cornell dans le forum Bases de données
    Réponses: 5
    Dernier message: 05/09/2003, 16h42
  3. Quel est l'intérêt des Services Web ??
    Par silvermoon dans le forum Débats sur le développement - Le Best Of
    Réponses: 19
    Dernier message: 12/02/2003, 22h28
  4. [Concept] BD ou Gestion par fichier. Intérêt de la BD ?
    Par Cian dans le forum Décisions SGBD
    Réponses: 3
    Dernier message: 28/11/2002, 12h16
  5. [Technique] Intérêt des index
    Par ddams dans le forum Décisions SGBD
    Réponses: 10
    Dernier message: 04/11/2002, 15h11

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo