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

Langage SQL Discussion :

sélectionner l'enregistrement supérieur le plus proche


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 57
    Points : 43
    Points
    43
    Par défaut sélectionner l'enregistrement supérieur le plus proche
    Bonjour,

    Je cherche à faire une requete sous Access selon l'exemple suivant :
    J'ai une table "Table_1" avec une colonne "C1" qui contient les valeurs 1,2,3,6,7,9,12
    Mon objectif est de créer une requête afin d'obtenir deux colonnes qui contiennent chaque valeur de Table_1.C1 dans la première, et dans la deuxième, la valeur de Table_1.C1 immédiatement supérieure :
    1 2
    2 3
    3 6
    6 7
    7 9
    9 12
    12 ? (idéalement 0 ici)
    J'aimerais trouver une rêquête la plus simple possible, sans créer de table intermédiaire, car en réalité mon problème est beaucoup plus complexe et le volume de données à traiter est immense, ma question ici synthétise le plus simplement le fond de mon problème.
    La requête idéale serait du genre :
    SELECT T1.C1, T2.C1 FROM Table_1 AS T1 INNER JOIN Table_2 AS T2 ON (condition)
    Merci de votre aide

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 920
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 920
    Points : 51 712
    Points
    51 712
    Billets dans le blog
    6
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT T1.C1, COALESCE(MIN(T2.C1), 0) 
    FROM   Table_1 AS T1 
           INNER JOIN Table_1 AS T2 
               ON T1.C1 < T2.C1
    GROUP  BY T1.C1
    A +

  3. #3
    Membre expérimenté
    Avatar de islamov2000
    Homme Profil pro
    Ingénieur d'études & developpement en informatique
    Inscrit en
    Septembre 2007
    Messages
    814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur d'études & developpement en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2007
    Messages : 814
    Points : 1 717
    Points
    1 717
    Billets dans le blog
    6
    Par défaut
    si la fonction COALESCE ne marche pas

    essaye

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    SELECT T1.C1,min(T2.C1)
     
    FROM   Table_1 AS T1 
           INNER JOIN Table_1 AS T2 
               ON T1.C1 < T2.C1
    GROUP  BY T1.C1
     
    union
     
    select max(T1.c1) ,0  from Table_1 as T1

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 57
    Points : 43
    Points
    43
    Par défaut
    Merci de vos reponses.
    L'idée est bonne et fonctionne très bien avec peu d'enregistrements.
    Mais je travaille avec des centaines de milliers d'enregistrement et la condition
    T1.C1<T2.C1 sur la jointure génère un temps de traitement considérable (j'ai testé et je n'ai pas eu la patience d'attendre la fin).

  5. #5
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 394
    Points
    18 394
    Par défaut
    Votre colonne est-elle indexée ?

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 57
    Points : 43
    Points
    43
    Par défaut
    Citation Envoyé par Waldar Voir le message
    Votre colonne est-elle indexée ?
    oui, le champ de la colonne C1 est une clé primare

  7. #7
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut !

    L'index n'aide pas, parce qu'Access doit sûrement déplier toute la jointure avant de chercher le min, ce qui peut faire beaucoup !

    Peut-être qu'en l'écrivant autrement Access pourrait utiliser l'index pour chercher le min ?

    Tente, si Access l'accepte :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT T1.C1, (SELECT max(T2.C1) FROM table_1 AS T2 WHERE T2.C1 < T1.C1) AS C2 
    FROM   Table_1 AS T1

  8. #8
    Membre expérimenté
    Avatar de islamov2000
    Homme Profil pro
    Ingénieur d'études & developpement en informatique
    Inscrit en
    Septembre 2007
    Messages
    814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Ingénieur d'études & developpement en informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2007
    Messages : 814
    Points : 1 717
    Points
    1 717
    Billets dans le blog
    6
    Par défaut
    une autre bonne solution par PACMANN

    mais pour répondre au besoin de JulienCEA ' j'ai modifié la requete comme suite

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT T1.C1, 
    iif((SELECT min(T2.C1) FROM table_1 AS T2 WHERE T2.C1 > T1.C1)is null,0,
    
    (SELECT min(T2.C1) FROM table_1 AS T2 WHERE T2.C1 > T1.C1)) AS C2 
    
    FROM   Table_1 AS T1

  9. #9
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 57
    Points : 43
    Points
    43
    Par défaut
    Merci Pacman ta solution est bien. En la testant je me rends compte qu'elle est très longue à s'éxécuter comme avec la jointure. Mais au moins on peut visualiser les résultats presque immédiatement.
    J'ai lancé un insert à partir de cette requete pour pouvoir travailler tranquilement sur une table intermédiaire. Et c'est là que le temps d'attente se fait ressentir.
    Finalement je ne pense pas que le SQL soit adapté à ce genre de travail. Je pense que je vais m'orienter vers la programmation.

  10. #10
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 920
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 920
    Points : 51 712
    Points
    51 712
    Billets dans le blog
    6
    Par défaut
    Si le SQL est parfaitement adapté, mais pas Access qui est un veau !
    Cette requête avec quelques centaines de milliers de ligne ne prendrait pas plus de quelques millisecondes sous Oracle, SQL Server ou PostGreSQL !

    A +

  11. #11
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 394
    Points
    18 394
    Par défaut
    Surtout sur Oracle où on pourrait utiliser LEAD

Discussions similaires

  1. [XL-2007] Extraire la valeur la plus proche supérieure d'une liste
    Par atk_49 dans le forum Excel
    Réponses: 11
    Dernier message: 04/07/2014, 08h30
  2. Réponses: 3
    Dernier message: 29/11/2012, 12h59
  3. [XL-2003] Date la plus proche et supérieure
    Par Fredche dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 05/02/2012, 20h15
  4. Enregistrement le plus proche de la date
    Par gudul dans le forum Langage SQL
    Réponses: 10
    Dernier message: 27/10/2008, 11h18
  5. Réponses: 10
    Dernier message: 06/03/2007, 15h36

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