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

Requêtes et SQL. Discussion :

Incrément d'après liste incomplète


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    134
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 134
    Points : 53
    Points
    53
    Par défaut Incrément d'après liste incomplète
    Bonjour à Tous,

    Un petit retour sur un problème non résolu. J'ai fouiné mais rouillé que je suis, je ne trouve pas le truc qui muche.

    * Etabli : une Table A avec champ CPO (clef prim), Objet, NumInv
    -> les valeurs dans NumInv sont numériques, mais ne suivent pas l'ordre de saisie CPO.

    * Souhaité 1 : à l'ajout d'une nouvelle entrée CPO, il faut que NumInv 'n' = le plus grand NumInv de la table entière +1.

    * Souhaité 2 : toutes les entrées déjà existantes ne comportent pas une valeur en NumInv ; il faut que NumInv 'x' = le plus grand NumInv de la table entière +1.


    => Ce que je comprends : il faut que ma requête porte sur la liste entière des NumInv déjà existants.

    J'avais essayé cela, mais à la réflexion et à l'expérience ,c'est absurde puisque cela ne répond pas à l'objectif "Souhaité 2" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT A.CPO, A.NumInv, 0+Nz(COUNT(B.CPO),0) AS Test
    FROM A INNER JOIN A AS B ON A.CPO>=B.CPO
    GROUP BU A.CPO, A.NumINV
    Comment faire svp ? Par un Select Count ? Par un modèle d'équation ?
    Merci beaucoup !

    Problématiquement vôtre,
    BK

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 339
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 339
    Points : 23 799
    Points
    23 799
    Par défaut
    Personnellement j'utiliserai DMax()+1 avec un petit bout de VBA bien qu'on doive pouvoir le faire avec une requête d'insertion.

    Voici le code que je ferai :

    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
    dim db as dao.database:set db=currentdb
    dim r as dao.recordset:set r=db.openRecordset("nomTaTable")
     
    do while not r.eof
     
       if isnull(r![NumInv]) then
          r.edit
          r![NumInv]=dmax("NumInv","NomTaTable")+1
          r.update
       end if
     
       r.movenext
    loop
     
    r.close:set r=nothing
    set db=nothing
    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

Discussions similaires

  1. Affichage d'après liste déroulante
    Par etudiant2290 dans le forum Général VBA
    Réponses: 0
    Dernier message: 07/09/2012, 09h00
  2. Incrémentation nom variable liste
    Par doulie dans le forum MATLAB
    Réponses: 1
    Dernier message: 07/07/2011, 20h01
  3. Probleme saut de ligne apres liste
    Par marty499 dans le forum Mise en forme
    Réponses: 4
    Dernier message: 23/05/2011, 11h31
  4. récupération variable apres liste de choix
    Par polux31 dans le forum Langage
    Réponses: 21
    Dernier message: 15/02/2011, 19h59
  5. [AJAX] Liste déroulante pour afficher les informations en ajax div ?
    Par rob2-9 dans le forum Général JavaScript
    Réponses: 13
    Dernier message: 17/11/2006, 09h06

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