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

Oracle Discussion :

Oracle : requête. problème selection d'enregistrement where ID <= 'chaine'. incohérence


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de ben.IT
    Homme Profil pro
    Inscrit en
    Janvier 2009
    Messages
    431
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Puy de Dôme (Auvergne)

    Informations forums :
    Inscription : Janvier 2009
    Messages : 431
    Par défaut Oracle : requête. problème selection d'enregistrement where ID <= 'chaine'. incohérence
    Salut à tous,
    je rencontre actuellement un problème :

    Sous oracle 11g,
    soit la table ma_table triée par id (varchar2) et numérotée dans la colonne nb.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    describe ma_table
    Nom                            NULL     Type                                                                                                                                                                                          
    ------------------------------ -------- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 
    ID                                  VARCHAR2(4000)                                                                                                                                                                                
    NB                                      NUMBER                                                                                                                                                                                        
     
    2 rows selected
    Le premier ID a pour NB 1, le second 2, le troisième 3, le nième n.
    Si je sélectionne l'id du 9999 enregistrement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    select ID from ma_table where nb ='9999'
    --retourne BE12345
     
    select count(*) 
    from ma_table
    where ID <= 'BE12345'
    J'obtiens 11369 au lieu de 9999.
    Je précise qu'il n y a pas de doublon au niveau des ID (ni nb).

    Quelqu'un peut il m'expliquer pourquoi cela ne fonctionne pas ?
    Qu'est ce qui se passe au niveau de la comparaison alphabétique des varchar pur l'ID ?

    merci d'avance,
    ben

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    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 454
    Par défaut
    Une table n'est JAMAIS triée (j'insiste un peu sur la mise en forme, car c'est important).

    Il faut visualiser une table comme étant un sac de billes.

    Qu'est-ce que la cinquième bille d'un sac de billes => ça peut être n'importe laquelle.

  3. #3
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 953
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 953
    Par défaut
    Citation Envoyé par ben.IT Voir le message
    Qu'est ce qui se passe au niveau de la comparaison alphabétique des varchar pur l'ID ?
    Avec un VARCHAR2 '10' < '2'
    Pour info pas besoin de quote autour d'un nombre :

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

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

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

    Pour moi, le problème est qu'on n'a pas de règle sur l'ID : ID <= 'BE12345' ne veut pas dire grand chose... à part un test de l'ordre alphabétique (en tous cas, certainement pas le nombre d'ID insérés avant celui-ci !)

    Plutôt :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT count(*) 
    FROM ma_table
    WHERE nb <= 9999

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 07/10/2008, 11h23
  2. problème requete : DELETE pr0 WHERE num1 in(select ..
    Par pierre.egaud dans le forum Oracle
    Réponses: 10
    Dernier message: 21/11/2006, 11h34
  3. Problème requète trop selective
    Par mouatte dans le forum Requêtes
    Réponses: 4
    Dernier message: 20/11/2006, 17h52
  4. [CR-XI] Problème paramètrage et selection d'enregistrement
    Par silversatch62 dans le forum SAP Crystal Reports
    Réponses: 3
    Dernier message: 13/10/2005, 21h42
  5. Problème select MAX(annee) dans une requête
    Par grisounette dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 28/10/2004, 17h36

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