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 :

Requête max() HyperfileSQL classic [WD15]


Sujet :

WinDev

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 11
    Points : 6
    Points
    6
    Par défaut Requête max() HyperfileSQL classic
    Bonjour

    Je vous contacte suite à petit problème avec une requête.

    J'ai un programme en HyperfilesSQL C/S qui utilise une simple
    requête avec la fonction max()
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT MAX(Rapport.n_rp) AS le_maximum_n_rp 
     
    FROM 
    Rapport 
     
    WHERE LEFT(Rapport.Date_rp,4) = LEFT(SYSDATE,4)
    Cette requête cherche le N° de rapport le plus élevé de l'année
    et cela fonctionne très bien en C/S.

    Pour une adaptation en HyperfileSQL Classic j'ai réutilisé la requête.
    Mais cela fonctionne trés bien avec l'éditeur de requete ou tout utilitaire SQL livré avec Windev sauf quand
    j'utilise HExécuteRequête() Dans le programme alors que la même
    commande fonctionne bien avec C/S.

    Si quelqu'un peut m'aider merci.

    Cordialement

  2. #2
    Membre averti

    Homme Profil pro
    Consultant informatique
    Inscrit en
    Janvier 2010
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gard (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2010
    Messages : 125
    Points : 399
    Points
    399
    Par défaut
    Bonjour,

    Qu'est ce qui ne fonctionne pas en HyperFile Classic? As tu un message d'erreur? ou il ne retourne pas d'enregistrements?

    Essaies d'être un peu plus précis, et si tu peux mets un extrait de ton code.

    Merci

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 11
    Points : 6
    Points
    6
    Par défaut Requête max() HyperfileSQL classic
    Bonjour

    En fait le nombre maximum doit apparaitre dans un champ
    de saisie

    Mais le resultat retourne 1 en Classic alors qu'en C/S retourne
    un resultat correcte.

    Le code
    le plus simple en teste

    Une fenêtre et a l'ouverture dans le code initialisation
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    HExécuteRequête(REQ_MaxNumero,Connexion_classic1,hRequêteDéfaut)
     
    //Sai_nrp est le champ de saisie
    SAI_nrp = REQ_MaxNumero.le_maximum_n_rp
    cela fonctionne avec l'éditeur de requête en classic mais pas
    dans le code.

    merci

  4. #4
    Membre expert
    Avatar de mail.spam
    Homme Profil pro
    Développeur Windev et technicien maintenance
    Inscrit en
    Janvier 2008
    Messages
    1 914
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Windev et technicien maintenance
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2008
    Messages : 1 914
    Points : 3 803
    Points
    3 803
    Par défaut
    Bonjour,

    C'est normale.

    Regarde bien dans l'aide de HExécuteRequête, il y a un exemple.
    Une fois ta requête exécuté, il faut te positionner sur le premier enregistrement.

    N'oublie pas non plus de tester la bonne exécution de ta requête

    voici l'exemple de l'aide

    // Initialise la requête
    SI PAS HExécuteRequête(MaRequête) ALORS
    Erreur("Erreur d'initialisation de la requête"+RC+HErreurInfo())
    RETOUR
    FIN

    // lecture du premier enregistrement de la requête
    HLitPremier(MaRequête)
    TANTQUE PAS HEnDehors()
    // Traitement sur l'enregistrement de la requête
    ...
    // lecture de l'enregistrement suivant
    HLitSuivant()
    FIN
    HAnnuleDéclaration(MaRequête)
    la touche est ton amie. l'aide ne mord pas quand on la consulte...
    PS : n'oubliez jamais que nous ne sommes pas avec vous sur le projet. Donc plus vous donnez d'informations et d'exemples de codes et plus nous pourrons vous aider. (Un exemple vaut mieux que de longs discours...)

    Pensez à utiliser les votes et à cliquer sur , merci

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 11
    Points : 6
    Points
    6
    Par défaut Requête max() HyperfileSQL classic
    Merci

    Merci pour l'aide en effet il faut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    HLitPremier(REQ_MaxNumero)
    et le code fonctionne
    je ferai plus attention

    merci
    Cordialement

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

Discussions similaires

  1. Sous requête MAX
    Par Erakis dans le forum Requêtes
    Réponses: 7
    Dernier message: 01/08/2006, 20h56
  2. Réponses: 4
    Dernier message: 26/05/2006, 08h59
  3. requête max sur plusieurs champs
    Par logica dans le forum Access
    Réponses: 3
    Dernier message: 28/03/2006, 16h31
  4. Requête Max
    Par ivan7 dans le forum Access
    Réponses: 3
    Dernier message: 17/03/2006, 17h50
  5. Requêtes Max ???
    Par aburner dans le forum ASP
    Réponses: 4
    Dernier message: 07/02/2005, 11h20

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