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

SQL Oracle Discussion :

Test différence entre 2 chaines


Sujet :

SQL Oracle

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    386
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 386
    Points : 220
    Points
    220
    Par défaut Test différence entre 2 chaines
    Bonjour,

    Si dans un select , je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    CASE WHEN 'AA' != '' THEN '1'
    ELSE '0'
    END AS TEST1
    il me retourne '0'. Comment faire pour avoir '1' pour '' chaine vide ou Null ?

    Merci d'avance pour votre aide.

    @+

  2. #2
    Membre averti Avatar de mongilotti
    Profil pro
    Inscrit en
    Février 2003
    Messages
    314
    Détails du profil
    Informations personnelles :
    Localisation : Tunisie

    Informations forums :
    Inscription : Février 2003
    Messages : 314
    Points : 303
    Points
    303
    Par défaut
    pour tester qu'une chaine et null il faut faire :
    CASE WHEN CH1 IS NULL THEN 1 ...

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    386
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 386
    Points : 220
    Points
    220
    Par défaut
    Oui mais j'ai besoin de comparer des chaines qui viennent de 2 tables (colonnes) différentes.

  4. #4
    Membre averti Avatar de mongilotti
    Profil pro
    Inscrit en
    Février 2003
    Messages
    314
    Détails du profil
    Informations personnelles :
    Localisation : Tunisie

    Informations forums :
    Inscription : Février 2003
    Messages : 314
    Points : 303
    Points
    303
    Par défaut
    tu dois nous expliquer un peu plus le besoin, à partir de quelle table, ...

  5. #5
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    386
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 386
    Points : 220
    Points
    220
    Par défaut
    Si je fais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT
    CASE
    WHEN 'AAA' != 'A' THEN '1'
    ELSE '0'
    END AS TEST
    FROM DUAL
    il me retourne '1' normal

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT
    CASE
    WHEN 'AAA' != ''THEN '1'
    ELSE '0'
    END AS TEST
    FROM DUAL
    il me retourne '0' alors que moi j'attends '1'.
    'AAA' est pour "moi" différent de ''

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2010
    Messages
    134
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 134
    Points : 71
    Points
    71
    Par défaut
    Citation Envoyé par Thomad Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT
    CASE
    WHEN 'AAA' != ''THEN '1'
    ELSE '0'
    END AS TEST
    FROM DUAL
    il me retourne '0' alors que moi j'attends '1'.
    'AAA' est pour "moi" différent de ''
    remplacer
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     WHEN 'AAA' != ''THEN '1'
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     WHEN 'AAA' IS NOT NULL THEN '1'
    Ne fonctionnerait-il pas?

  7. #7
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    386
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 386
    Points : 220
    Points
    220
    Par défaut
    Oui c'est une solution mais j'aimerais bien pouvoir comparer les deux valeurs qui viennent de mes deux différentes colonnes (table1.colonne1 != table2.colonne2).

    C'est doit quand même être possible, sous Oracle, ce genre de truc !!

  8. #8
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Citation Envoyé par Thomad Voir le message
    Oui c'est une solution mais j'aimerais bien pouvoir comparer les deux valeurs qui viennent de mes deux différentes colonnes (table1.colonne1 != table2.colonne2).

    C'est doit quand même être possible, sous Oracle, ce genre de truc !!
    Alors vous auriez dû commencer par poser la bonne question, au lieu de demander "Comment faire pour avoir '1' pour '' chaine vide ou Null ?" !

    Il faut remplacer vos chaînes vides (NULL pour Oracle) par des chaînes non nulles avant de faire la comparaison :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from t where nvl(a, 'VIDE')<>nvl(b, 'VIDE');
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  9. #9
    Membre actif
    Profil pro
    Inscrit en
    Septembre 2002
    Messages
    386
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2002
    Messages : 386
    Points : 220
    Points
    220
    Par défaut
    Pour comparer des chaines:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    SELECT
    CASE
    WHEN NULLIF(
    UPPER(LTRIM(RTRIM(TO_CHAR('AAA'))))
    ,
    UPPER(LTRIM(RTRIM(TO_CHAR(''))))
    ) IS NULL THEN 'PAS DE DIFFERENCE'
    ELSE
    'DIFFERENCE'
    END AS TEST
    FROM DUAL
    Merci.

    Bonne journée.

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

Discussions similaires

  1. nombre de différence entre 2 chaines de caratère
    Par solen dans le forum Langage
    Réponses: 8
    Dernier message: 12/06/2008, 11h39
  2. [BO XIr2] Tests sur des différences entre dates
    Par Enthau dans le forum Deski
    Réponses: 4
    Dernier message: 27/07/2007, 10h49
  3. [pb MD5 MySql et C#]Différence entre les chaines
    Par ludovic85 dans le forum C#
    Réponses: 1
    Dernier message: 31/01/2007, 21h11
  4. différence entre test et réalité
    Par Pallas4 dans le forum Flash
    Réponses: 6
    Dernier message: 17/08/2006, 12h45
  5. [Tests] Différence entre JUnit et Cactus ?
    Par pamic dans le forum Tests et Performance
    Réponses: 13
    Dernier message: 25/08/2005, 10h20

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