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 :

[VS2010][C#] ADO.net placer le résultat d'une procédure stockée dans un datagridview


Sujet :

C#

  1. #1
    Membre actif Avatar de stolx_10
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2006
    Messages
    374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 374
    Points : 270
    Points
    270
    Par défaut [VS2010][C#] ADO.net placer le résultat d'une procédure stockée dans un datagridview
    Bonjour

    Je voudrais envoyer le résultat de cette chaîne de caractère compatible SQL Server :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    EXEC PR_AGENTS_PREP_SELECTION 0,'DDSIS520001' ,'CRSS' ,'SIS' ,'0' ,'1' ,'0' ,'0' ,'0' ,'0' ,'9' ,''' Order by ag.matricule ASC ''' ,'' ,'' ,'' ,'N' ,'N'
    dans un datagridview.

    Je fais un truc du genre, comme pour une requête "select"

    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    //macommande = "EXEC PR_AGENTS_PREP_SELECECTION............................."
                    OdbcCommand dataSQL = new OdbcCommand(macommande, GO_Init.conn);
                    //type procedure stockée
                    dataSQL.CommandType = CommandType.StoredProcedure; // est-ce bien raisonnable ?
     
                    OdbcDataAdapter DA = new OdbcDataAdapter(dataSQL);
     
                    DataSet dt = new DataSet("ListeAgents");
                    DA.Fill(dt);
                    DBG_LAgents.DataSource = dt;
     
                    DBG_LAgents.AutoResizeColumns(
                        DataGridViewAutoSizeColumnsMode.AllCells);

    Bref, ça ne marche pas. Le datasource reste vide.

    J'ai regardé un peu partout comment on utilisait les procédures stockées via c# et ADO, mais tout passe par des paramètres envoyés par le code C#. Et moi je voudrais envoyer directement ma chaîne SQL comme indiqué ci-dessus.

    Est-ce possible ? ou dois-je obligatoirement appeler ma parocédure via des parametres.add ?

    Merci pour vos réponses

  2. #2
    Membre actif Avatar de stolx_10
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2006
    Messages
    374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 374
    Points : 270
    Points
    270
    Par défaut
    Bon j'ai trouvé une solution.

    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
     
                    //OdbcDataAdapter dataSQL = new OdbcDataAdapter(macommande, GO_Init.conn);
                    OdbcCommand dataSQL = new OdbcCommand(macommande, GO_Init.conn);
                    //type procedure stockée
                    OdbcDataReader read = dataSQL.ExecuteReader();
     
                    DataSet ds = new DataSet();
     
                    DataTable dt = new DataTable("Table1");
     
                    ds.Tables.Add(dt);
     
                    ds.Load(read, LoadOption.PreserveChanges, ds.Tables[0]);
     
                    DBG_LAgents.DataSource = ds.Tables[0];
    J'arrive donc à peupler mon datagridview (DBG_LAgents).

    J'ai un autre problème : ne prendre en compte que certaines colonnes et non toutes les colonnes que me retourne ma procédure.
    Je pense trouver la solution qui me semble simple, donner à mes colonnes le même nom que les colonnes de ma source.

    Je mets en résolu

  3. #3
    Membre actif Avatar de stolx_10
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2006
    Messages
    374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 374
    Points : 270
    Points
    270
    Par défaut
    Je pense trouver la solution qui me semble simple, donner à mes colonnes le même nom que les colonnes de ma source.
    Effectivement c'était bien ça , et puis aussi, j'ai ajouté cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    DBG_LAgents.AutoGenerateColumns = false;
    Cela permet de générer uniquement les colonnes souhaitées, sans pour autant en générer d'autres.

    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
                    //OdbcDataAdapter dataSQL = new OdbcDataAdapter(macommande, GO_Init.conn);
                    OdbcCommand dataSQL = new OdbcCommand(macommande, GO_Init.conn);
                    //type procedure stockée
                    OdbcDataReader read = dataSQL.ExecuteReader();
     
                    DataSet ds = new DataSet();
     
                    DataTable dt = new DataTable("Table1");
     
                    ds.Tables.Add(dt);
     
                    ds.Load(read, LoadOption.PreserveChanges, ds.Tables[0]);
     
                    DBG_LAgents.AutoGenerateColumns = false;
                    DBG_LAgents.DataSource = ds.Tables[0];
     
                    DBG_LAgents.AutoResizeColumns(
                        DataGridViewAutoSizeColumnsMode.AllCells);
    Exemple :
    la requête renvoie les colonnes A, B,C,D,E,F,G
    Mon datagridview ne veut que A,C,E (donner pour chacune des 3 colonnes du DGW le datapropertyname associé, soit A pour la 1ère colonne, C la 2nde et E la 3eme)

    et voilà

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

Discussions similaires

  1. [Débutant] Afficher le résultat d'une procédure stockée dans des contrôles
    Par Bakkach dans le forum VB.NET
    Réponses: 4
    Dernier message: 20/05/2013, 18h08
  2. [ADO.Net][C#] Comment combiner IDbCommand et procédures stockées ?
    Par L`artiste dans le forum Accès aux données
    Réponses: 7
    Dernier message: 19/08/2011, 16h44
  3. [ADO.NET] Récupérer le résultat d'une requête dans une variable
    Par developppez dans le forum Accès aux données
    Réponses: 2
    Dernier message: 14/03/2009, 21h34
  4. [DELPHI 6.0][ADO] Récupérer le résultat d'une procédure stockée
    Par Invité dans le forum Bases de données
    Réponses: 3
    Dernier message: 26/05/2008, 10h24
  5. [C#] Récupérer le résultat d'une procédure stockée
    Par fabrice1596 dans le forum Windows Forms
    Réponses: 3
    Dernier message: 18/10/2004, 13h45

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