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

C# Discussion :

Remplir un DataSet avec toute la base


Sujet :

C#

  1. #1
    Membre habitué

    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 162
    Points : 179
    Points
    179
    Par défaut Remplir un DataSet avec toute la base
    Bonjour,

    Voilà j'essai d’accéder à une base de donnée Access en C# et j’utilise cette méthode pour récupérer le contenu d’une table dans un Dataset.

    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    string Requete = "select * from " + TableName;
    System.Data.DataSet DtSet = new System.Data.DataSet();
    System.Data.OleDb.OleDbDataAdapter AdapTContact = new System.Data.OleDb.OleDbDataAdapter(Requete, Connection);AdapTContact.Fill(DtSet, ((char)0).ToString());
    DtSet.Tables[0].TableName = TableName;
    return DtSet.Tables[0];

    Cette méthode nécessite de connaitre le nom de la table ou des tables pour remplir le Dataset.

    Ma question est la suivante, Y a-t-il un moyen de récuperer tout le contenu de ma base dans un Dataset sans me faire toutes les tables une par une ?

    Imaginons par exemple que je ne connaisse pas le nom des tables de ma base.
    J’ai essayer de mettre Select * from * dans la requête mais cela ne marche pas.

    merci

  2. #2
    Membre averti
    Inscrit en
    Décembre 2005
    Messages
    391
    Détails du profil
    Informations personnelles :
    Âge : 49

    Informations forums :
    Inscription : Décembre 2005
    Messages : 391
    Points : 301
    Points
    301
    Par défaut
    il faut trouver l instruction sql qui retourne les tables de ta base

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    764
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 764
    Points : 909
    Points
    909
    Par défaut
    Pour récupérer les noms de tes tables tu peux faire quelque chose du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    connection.Open();
    DataTable dt = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
    connection.Close();
    foreach (DataRow row in dt.Rows)
    {
    	string tableName = (string)row["TABLE_NAME"];
    	// j'ai un nom de table...
    }
    Par contre, attention, on récupère aussi les tables de métadonnées... Par exemple, avec Access, on récupère les tables "MSysObjects", "MySysQueries", "MySysAccessStorage", etc.

  4. #4
    Membre habitué

    Homme Profil pro
    Inscrit en
    Juillet 2007
    Messages
    162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 162
    Points : 179
    Points
    179
    Par défaut
    Les deux méthodes sont effectivement possibles.

    L'utilisation du GetOleDbSchemaTable est simple, je vais essayer de voir si il est possible de ne pas remonter les tables de métadonnées mais sinon c'est parfait.


    merci

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    764
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 764
    Points : 909
    Points
    909
    Par défaut
    S'il existe effectivement une requête SQL qui te donne les noms de tes tables, utilise plutôt cette méthode, ça sera sûrement beaucoup moins lourd !
    Dans tous les cas il y a une connexion à la base avec récupération de données, mais avec ma proposition on récupère pleins d'infos inutiles, qui de plus sont stockées dans une DataTable (donc plus lourd à traiter qu'un DataReader).

  6. #6
    Expert éminent Avatar de Graffito
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    5 993
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 993
    Points : 7 903
    Points
    7 903
    Par défaut
    Bonjour,

    Il existe dans les database Access une table "cachée" qui contient la liste de toutes les autres tables.

    Donc un select sur cette table (peut-être MSysObjects de mémoire) donnera la liste que tu recherches.

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

Discussions similaires

  1. remplir un dataset avec une valeur null
    Par bellak dans le forum Windows Forms
    Réponses: 5
    Dernier message: 21/10/2008, 18h49
  2. Réponses: 6
    Dernier message: 30/05/2008, 11h46
  3. Remplir une table avec toutes les dates de l'année
    Par sialafrere dans le forum WinDev
    Réponses: 6
    Dernier message: 02/05/2008, 16h45
  4. Remplir une liste avec TOUT le contenu d'une combo
    Par jo_la_pasteque dans le forum WinDev
    Réponses: 8
    Dernier message: 14/04/2008, 12h49
  5. Comment remplir un Dataset avec toutes les tables d'une db?
    Par Mr_Welby dans le forum Accès aux données
    Réponses: 1
    Dernier message: 14/05/2007, 15h29

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