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 :

Dataset par code


Sujet :

Windows Forms

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut Dataset par code
    Bonjour,

    En bon débutant soucieux de comprendre tous les mécanismes d'accès aux données par ADO.NET, je cherche à créer un dataset par code. Mais je rame ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    sqlConnection1.ConnectionString = "Data Source=.\\SQLEXPRESS;Initial Catalog=\"PERSONNES\";Integrated Security=True;Connect Timeout=30;User Instance=False;Context Connection=False";
     
    SqlDataAdapter sda = new SqlDataAdapter("", sqlConnection1);
    sda.SelectCommand.CommandText = "SELECT * FROM PRODUITS";
    DataSet monDataSet = new DataSet("Produits");
    sda.Fill(monDataSet);
     
    dataGridView1.DataSource = monDataSet.Tables[0];
    Jusque là, tout va bien, et les données sont bien affichées dans ma grille.
    Mais ça, ça crée une seule table dans mon dataset.
    Comment je dois faire pour en créer d'autres à l'intérieur ?
    J'ai esayé:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    sda.SelectCommand.CommandText = "SELECT * FROM PHOTOS";
    sda.Fill(monDataSet);
    .. en espérant que ça créerait une seconde table mais quand j'essaye de lier

    dataGridView2.DataSource = monDataSet.Tables[1];

    VS me dit à l'execution que Table[1] n'existe pas.

    C'est où que j'ai faux ?

    J-L

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    62
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2007
    Messages : 62
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    sqlConnection1.ConnectionString = "Data Source=.\\SQLEXPRESS;Initial Catalog=\"PERSONNES\";Integrated Security=True;Connect Timeout=30;User Instance=False;Context Connection=False";
     
    SqlDataAdapter sda = new SqlDataAdapter("", sqlConnection1);
    sda.SelectCommand.CommandText = "SELECT * FROM PRODUITS SELECT * FROM PHOTOS";
     
    DataSet monDataSet = new DataSet("Produits");
    sda.Fill(monDataSet);
    la t'as pas les 2 tables remplis ????

  3. #3
    Membre Expert

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut
    Là oui ... Mais je n'aurais jamais eu l'idée de mettre 2 requètes comme ça l'une derrière l'autre ...

    C'est la manière classique de procéder ?

  4. #4
    Membre éclairé
    Inscrit en
    Avril 2006
    Messages
    346
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 346
    Par défaut
    Voici un lien qui pourrait t'interesser:

    http://www.supinfo-projects.com/fr/2005/datatype/3/

    Mais comment bien utiliser les proprietés selectCommand, insertCommand, deleteCommand, et updateCommand quand on travaille sur plusieurs tables ? Car on ne peut traiter qu'une seule table à la fois .... !

    Voici un autre lien dans lequel le sujet a été traité:
    http://www.developpez.net/forums/sho...d.php?t=441760

    Bye

  5. #5
    Membre éprouvé
    Avatar de debug
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    1 034
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 034
    Par défaut
    Il faut que tu ajoutes tes différentes tables à ton dataset par :
    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    mondataset = new DataSet();
    mondataset.Tables.Add("matableproduit");
    mondataset.Tables.Add("matablephoto");

    Ensuite dans ton data adapter, tu "fill" la table que tu veux par :

    Code c# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    sda.SelectCommand.CommandText = "SELECT * FROM PRODUITS";
    sda.Fill(monDataSet.Tables("matableproduit"));
     
    sda.SelectCommand.CommandText = "SELECT * FROM PHOTOS";
    sda.Fill(monDataSet.Tables("matablephoto"));

  6. #6
    Membre Expert 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
    Par défaut
    +1 pour debug
    Cette utilisation est beaucoup plus lisible donc utilisée et surtout plus souple car on ajoute ou retire une table avec une simplicité enfantine.

  7. #7
    Membre Expert

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 530
    Par défaut
    zoaax .. merci pour les liens

    debug ... cette façon de faire me semble plus plus claire :-) , merci

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

Discussions similaires

  1. Fermeture fenetre crée par code javascript
    Par Kerod dans le forum Général JavaScript
    Réponses: 9
    Dernier message: 27/02/2010, 00h04
  2. Tri par Codes Postaux + Noms d'entreprises
    Par matperino dans le forum Langage SQL
    Réponses: 2
    Dernier message: 21/07/2005, 14h04
  3. Retirer une clé primaire par code
    Par Arrown dans le forum Bases de données
    Réponses: 3
    Dernier message: 28/07/2004, 15h15
  4. [VCL] Scroller un contrôle par code
    Par sbeu dans le forum Composants VCL
    Réponses: 3
    Dernier message: 31/03/2004, 10h39
  5. [VB6] Datagrid afficher ou cacher des colonnes par code
    Par soazig dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 06/02/2003, 17h19

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