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 :

construire une requete dynamique


Sujet :

C#

  1. #1
    Membre averti Avatar de solo190
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Avril 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Cameroun

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 412
    Points : 321
    Points
    321
    Par défaut construire une requete dynamique
    bonjour a tous,
    j'ai ecris une methode pour executer une procedure stockée sur une base de donnée sql serveur 2000, lorsque je met les variables en paramètre sa ne marche pas par contre lorsque je lè met en dur tout ce passe bien, j'aimerais que vous me donner un coup de main dans la formation dynamique de ma chaine.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    public void execute()
            {
                // exeution de la procedure stockée 
                SqlConnection connexion = new SqlConnection("Data Source=("+Serveur+"); Initial Catalog=("+Nom_Bd+");" +
                                                              "Integrated Security=SSPI;");
                //SqlConnection connexion = new SqlConnection("Data Source=ICS-DEV1;  Initial Catalog=SMS;"+
                //                                         "Integrated Security=SSPI;");
                connexion.Open();
                SqlCommand cmdBD = new SqlCommand(Nom_Procedure, connexion);
                cmdBD.CommandType = CommandType.StoredProcedure;
                cmdBD.Parameters.Add("@Nom_utilisateur", SqlDbType.NVarChar).Value = Parametre1;
                cmdBD.Parameters.Add("@Passwords", SqlDbType.NVarChar).Value = Parametre2;
    	    cmdBD.ExecuteNonQuery();
            }
    Merci
    www.etech-keys.com
    https://sms.etech-keys.com

    le boiteux qui suit le chemin devance le coureur qui s'en écarte .

  2. #2
    Membre éprouvé Avatar de kheironn
    Homme Profil pro
    Chef de projets technique C# / MVC / .Net
    Inscrit en
    Février 2007
    Messages
    822
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Chef de projets technique C# / MVC / .Net
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2007
    Messages : 822
    Points : 1 108
    Points
    1 108
    Par défaut
    Quel est le problème exactement ?
    En informatique, le problème se situe toujours entre le clavier et l'écran !
    Il y a deux chemins entre le clavier et l'écran : Par l'UC et par l'utilisateur.

  3. #3
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Points : 13 314
    Points
    13 314
    Par défaut
    Poste le DDL header de ta procédure stockée.

    Je ne réponds pas aux questions techniques par MP ! Le forum est là pour ça...


    Une réponse vous a aidé ? utiliser le bouton

    "L’ennui dans ce monde, c’est que les idiots sont sûrs d’eux et les gens sensés pleins de doutes". B. Russel

  4. #4
    Membre averti Avatar de solo190
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Avril 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Cameroun

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 412
    Points : 321
    Points
    321
    Par défaut je presise le probleme
    lorsque les parametres sont passés a la procedure, connexion.Open() genere une erreur, tandis que lorsqu'ils sont mis en dure comme dans la partie en commentaire, tout ce passe bien.
    www.etech-keys.com
    https://sms.etech-keys.com

    le boiteux qui suit le chemin devance le coureur qui s'en écarte .

  5. #5
    Modérateur

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2007
    Messages
    1 996
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 996
    Points : 3 102
    Points
    3 102
    Par défaut
    Le mieux serait peut-être de stocker ces informations dans un fichier de configuration, en dur, et de récupérer cette chaîne via la classe ConfigurationManager.
    Cela éviterait les concaténations hasardeuses.
    Regarde ce tutoriel

  6. #6
    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
    Citation Envoyé par solo190 Voir le message
    lorsque les parametres sont passés a la procedure, connexion.Open() genere une erreur, tandis que lorsqu'ils sont mis en dure comme dans la partie en commentaire, tout ce passe bien.
    Dans un cas t'as mis des parenthèses, dans l'autre non.
    "Data Source=("+Serveur+"); Initial Catalog=("+Nom_Bd+");"
    ಠ_ಠ

  7. #7
    Membre averti Avatar de solo190
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Avril 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Cameroun

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 412
    Points : 321
    Points
    321
    Par défaut
    la partie en commentaire qui n'a pas de parenthèse est celle qui marche mes avec des parametres en dur.
    www.etech-keys.com
    https://sms.etech-keys.com

    le boiteux qui suit le chemin devance le coureur qui s'en écarte .

  8. #8
    Modérateur

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2007
    Messages
    1 996
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 996
    Points : 3 102
    Points
    3 102
    Par défaut
    Ce que tu dis Guulh est bon :
    - dans la version en dur, tu n'as pas de parenthèses et ta chaîne est correcte
    - dans la version concaténée, tu as des parenthèses et ta chaîne n'est pas bonne.

    Concatène tes paramètres sans parenthèses :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SqlConnection connexion = new SqlConnection("Data Source="+Serveur+"; Initial Catalog="+Nom_Bd+";" + "Integrated Security=SSPI;");
    Cela dit, je persiste, tu n'aurais pas ce problème en stockant ta chaine dans un fichier de configuration.

  9. #9
    Membre averti Avatar de solo190
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Avril 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Cameroun

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 412
    Points : 321
    Points
    321
    Par défaut j'ai finalement trouvé la solution
    avec le tutoriel que ma proposé calagan99,
    j'ai trouvé la solution au problème.
    voici mon fichier de config
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
      <appSettings>
        <add key="MaConnection" value= "Data Source=ICS-DEV1; Initial Catalog=SMS; Integrated Security=SSPI"/>
      </appSettings>
      </configuration>
    et voici comment je recupere la chaine de connexion
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    string chaine_connexion = null;
                chaine_connexion = ConfigurationManager.AppSettings["MaConnection"];
                SqlConnection connexion = new SqlConnection(chaine_connexion);
    www.etech-keys.com
    https://sms.etech-keys.com

    le boiteux qui suit le chemin devance le coureur qui s'en écarte .

  10. #10
    Modérateur

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2007
    Messages
    1 996
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 996
    Points : 3 102
    Points
    3 102
    Par défaut
    Voila une solution qui me paraît tout à fait adaptée

    Tu peux passer le topic en résolu si tu as eu la réponse à ta question.

  11. #11
    Membre Expert

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Points : 5 724
    Points
    5 724
    Par défaut
    Remarque que pour construire des connexionstring il existe la classe SqlConnectionStringBuilder
    http://msdn.microsoft.com/fr-fr/libr...ngbuilder.aspx

    Cela évite de faire des concaténations 'hasardeuses'
    " Dis ce que tu veux qui insulte mon honneur car mon silence sera la réponse au mesquin.
    Je ne manque pas de réponse mais : il ne convient pas aux lions de répondre aux chiens ! " [Ash-Shafi'i ]

  12. #12
    Modérateur

    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2007
    Messages
    1 996
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 996
    Points : 3 102
    Points
    3 102
    Par défaut
    Citation Envoyé par hegros Voir le message
    Remarque que pour construire des connexionstring il existe la classe SqlConnectionStringBuilder
    http://msdn.microsoft.com/fr-fr/libr...ngbuilder.aspx

    Cela évite de faire des concaténations 'hasardeuses'
    Bien vu, c'était aussi une alternative crédible

  13. #13
    Membre éprouvé Avatar de kheironn
    Homme Profil pro
    Chef de projets technique C# / MVC / .Net
    Inscrit en
    Février 2007
    Messages
    822
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Chef de projets technique C# / MVC / .Net
    Secteur : Conseil

    Informations forums :
    Inscription : Février 2007
    Messages : 822
    Points : 1 108
    Points
    1 108
    Par défaut
    Plutôt que d'utiliser les clefs de config, je préfère passer par les settings du programme et faire appel à mon élémet avec un nom fort :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Properties.Settings.Default.[le nom de la chaine]
    . Tu peux en plus définir une portée et typer en connexion string.
    En informatique, le problème se situe toujours entre le clavier et l'écran !
    Il y a deux chemins entre le clavier et l'écran : Par l'UC et par l'utilisateur.

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

Discussions similaires

  1. [LINQ] - créer une requete dynamique (pas en dur)
    Par DonJR dans le forum Général Dotnet
    Réponses: 1
    Dernier message: 08/06/2007, 10h30
  2. [LINQ] - créer une requete dynamique (pas en dur)
    Par DonJR dans le forum Général Dotnet
    Réponses: 1
    Dernier message: 08/06/2007, 10h30
  3. construire une requete dynamiquement
    Par highman dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 23/04/2007, 11h49
  4. [reports] comment créer une requete dynamiquement
    Par lifeisgood dans le forum Reports
    Réponses: 4
    Dernier message: 31/01/2007, 12h15
  5. PHP : construire une requete SQL
    Par Commodore dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 27/07/2006, 08h59

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