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

DB2 Discussion :

Utilisation du LIKE sur des variables de type integer castées en CHAR


Sujet :

DB2

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 16
    Par défaut Utilisation du LIKE sur des variables de type integer castées en CHAR
    Bonjour à tous, je me suis inscrit sur ce forum qui me semble très actif

    Je connais actuellement quelques problèmes sur des requêtes utilisant le mot clé LIKE, sur des donnés de type INTEGER : J'aimerais afficher toutes les données d'une table EMPLOYÉ lorsque l'identifiant de l'employé se termine par 1.

    La variable ID_EMP est un INTEGER de taille 10.

    Pour se faire voici la requête qui a été développée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT ID_EMP, CAST(ID_EMP AS CHAR(10))
    FROM DB.TE_EMP
    WHERE ID_EMP IN (1,10797,81,2881,120741)
    AND CAST(ID_EMP AS CHAR(10)) LIKE '%1'
    WITH UR
    Si je mets en commentaire la 4ème ligne, cela m'affiche toutes les données, ce qui me permet d'affirmer les ID_EMP est bien casté en CHAR.

    Si je dé-commente la 4ème ligne, le résultat retourné est 0 lignes, Empty result set fetched donc aucune donnée n'est trouvée alors que je m'attends à avoir 4 lignes retournée. Je pense que le problème vient du LIKE et du '%1', peut-être du simple quote qui déglingue le symbole %.

    Si ma contrainte est = '81' au lieu de LIKE '%1' alors j'ai bien un résultat.

    Donc sur le coup, je sèche un peu et je ne vois pas d'autre façon d'afficher les employés se terminant par 1.

    Est-ce que quelqu'un aurait une idée sur la manière d'agir pour arriver au résultat souhaité ? Merci d'avance pour la lecture de ce message et pour votre aide.

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    1 298
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 298
    Par défaut
    Essaie

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ... AND TRIM( CAST ( ID_EMP AS CHAR( 10 ) ) ) LIKE '%1' ...
    car la fonction CAST AS CHAR supprime les zéros non significatifs et cadre à GAUCHE dans la zone castée. La fonction TRIM() supprimera les blancs à gauche et à droite de la zone castée qui deviendra donc cohérente avec ce que tu cherches à faire.

  3. #3
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 16
    Par défaut
    Merci pour ta réponse Mercure, malheureusement cela me renvoie une erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    [Error Code: -440, SQL State: 42884]  
    No authorized routine named "TRIM" of type "FUNCTION" having 
    compatible arguments was found.
    Je vais analyser l'erreur renvoyée, et essayer de la comprendre.

  4. #4
    Membre émérite Avatar de Peut-êtreUneRéponse
    Homme Profil pro
    IT Specialist - IBM Z
    Inscrit en
    Décembre 2006
    Messages
    548
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : IT Specialist - IBM Z
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2006
    Messages : 548
    Par défaut
    RTRIM

  5. #5
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 16
    Par défaut
    Englober le bloc CAST dans le bloc RTRIM a permis de réussir la requête et d'afficher le résultat attendu.
    Merci beaucoup pour vos réponses très rapides et efficaces.

  6. #6
    Membre Expert

    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    1 298
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 298
    Par défaut
    Grrr...

  7. #7
    Membre émérite
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    821
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Mai 2008
    Messages : 821
    Par défaut
    Plus simplement :

    ...AND RIGHT(ID_EMP, 1) = 1

    ainsi pas besoin de casting

  8. #8
    Membre Expert

    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    1 298
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 298
    Par défaut
    En es-tu bien sûr ?

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

Discussions similaires

  1. Réponses: 22
    Dernier message: 03/01/2008, 22h42
  2. [RegEx] utilisation de preg_replace sur des balises
    Par Kerod dans le forum Langage
    Réponses: 5
    Dernier message: 09/12/2005, 13h46
  3. Réponses: 5
    Dernier message: 13/07/2005, 10h03
  4. [DB2] LIKE sur des entiers
    Par heloise dans le forum DB2
    Réponses: 1
    Dernier message: 07/10/2004, 23h30
  5. Réponses: 4
    Dernier message: 15/12/2002, 04h19

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