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

WinDev Discussion :

récupérer un enregistrement d'une table Mysql [WD17]


Sujet :

WinDev

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    187
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 187
    Points : 69
    Points
    69
    Par défaut récupérer un enregistrement d'une table Mysql
    Bonjour,

    Je cherche(certainement mal) depuis des heures à récupérer un enregistrement d'une table mysql pour le stocker dans une variable de type chaine.

    Je pensais utilisé un tableau virtuel mais je n'arrive à rien, juste me renvoyer l'indice de ma colonne.

    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
     
     
    Res est une chaîne
     
    ConnexionBase()
     
     
     
    sRes=SQLExec(" select  *  from  numfact","req1")
    SQLInfoGene()
     
     
    SQLFerme("req1")
    SQLDéconnecte()
     
    Info(sRes)
    Merci d'avance pour votre aide.

  2. #2
    Membre éprouvé Avatar de miripesage
    Homme Profil pro
    gerant
    Inscrit en
    Novembre 2009
    Messages
    725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : gerant
    Secteur : Industrie

    Informations forums :
    Inscription : Novembre 2009
    Messages : 725
    Points : 1 156
    Points
    1 156
    Par défaut
    Bonjour, pour lire la requête et afficher le résultat des colonnes :

    Citation Envoyé par jer64 Voir le message
    Bonjour,

    Je cherche(certainement mal) depuis des heures à récupérer un enregistrement d'une table mysql pour le stocker dans une variable de type chaine.

    Je pensais utilisé un tableau virtuel mais je n'arrive à rien, juste me renvoyer l'indice de ma colonne.

    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
     
     
    //Res est une chaîne
     
    ConnexionBase()
     
     
     
    sRes=SQLExec(" select  *  from  numfact","req1")//booléen
     
    si sRes=Vrai alors
    SQLPremier("req1")        
            TANTQUE PAS SQL.EnDehors
                    ListeAjoute(Liste_Colonnes, SQLCol("REQ1", 1))//Afficher dans liste
                    SQLSuivant("req1")
          SINON
    SQLInfoGene()
    FIN
     
    SQLFerme("req1")
    SQLDéconnecte()
     
    //Info(sRes)
    Merci d'avance pour votre aide.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    187
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 187
    Points : 69
    Points
    69
    Par défaut
    Bonjour,

    Merci pour ton aide, mais je ne comprends pas une chose :

    "Liste_colonnes" fait référence à un champs liste à moins que je ne me trompe.

    Mois je voudrais récupérer mon résultat dans une variable type chaine ou numérique sans avoir à créer de champ.

    Merci d'avance.

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 242
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 242
    Points : 12 874
    Points
    12 874
    Par défaut
    Bonjour,
    Est-ce que la requête renvoie plusieurs lignes et/ou plusieurs colonnes ?
    Si ce n'est pas le cas il suffit de supprimer la boucle:
    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
     
    Res est une chaîne
     
    ConnexionBase()
     
     
     
    sRes=SQLExec(" select  *  from  numfact","req1")
    si sqlavance("req1") = 0
    res = sqllitcol("req1",1)
    fin
     
    SQLFerme("req1")
    SQLDéconnecte()
     
    Info(sRes)
    Par contre si la requête renvoie plusieurs lignes, il faut faire une boucle comme l'a indiqué miripesage.

    Plus d'infos et .

    Tatayo.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    187
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 187
    Points : 69
    Points
    69
    Par défaut
    Bonjour,

    Merci beaucoup ça marche parfaitement. C'était bien une requête qui renvoie sur une ligne.

    Juste une chose qui me surprends : si la donnée dans ma table est "Null" cela me renvoi le résultat "1", si la donnée existe, j'ai le bon résultat. J'ai du louper quelque chose, mais mon problème immédiat est résolu.

    Merci encore.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 02/07/2012, 09h17
  2. Réponses: 7
    Dernier message: 08/03/2007, 16h42
  3. Afficher enregistrement d'une table MySQL
    Par oldscrout dans le forum Administration
    Réponses: 7
    Dernier message: 29/03/2006, 14h24
  4. Nombre d'enregistrement dans une table MySQL
    Par tom06440 dans le forum SQL Procédural
    Réponses: 7
    Dernier message: 21/10/2005, 19h07
  5. Récupérer dernier enregistrement d'une table?
    Par Invité dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 19/01/2004, 11h38

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