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 :

LIKE dans un champ de type LONG


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    68
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 68
    Par défaut LIKE dans un champ de type LONG
    Bonjour,

    J'aimerais faire une recherche de caractères dans un champs de type LONG.
    Le LIKE est utilisé pour les recherche dans les champs de type texte, donc comment faire pour trouver le même résultats sur un LONG?

    D'avance merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 291
    Par défaut
    tout pareil !

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    68
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 68
    Par défaut
    Heuuu, je ne sais pas pourquoi ça ne marche pas.

    Je fais: LOG.DETAILS LIKE '%Deadline%'

    Et j'ai le message suivant "ORA-00932: inconsistent datatypes: expected NUMBER got LONG"...

    Je ne comprend pas, merci pour ta réponse

  4. #4
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 291
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 291
    Par défaut
    Pardon, je pensais que LONG était un type numérique (je suis dans VB en ce moment ).

    Je constate que la doc Oracle précise :

    Do not create tables with LONG columns. Use LOB columns (CLOB, NCLOB, BLOB) instead. LONG columns are supported only for backward compatibility.
    Ton message d'erreur est un peu surprenant... Essaie déjà comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    CAST(LOG.DETAILS AS VARCHAR2(255)) LIKE '%Deadline%'

  5. #5
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    68
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 68
    Par défaut
    Aucun problème

    En effet, je trouve aussi un peut bizarre qui des LONG soit utilisés dans cette table, mais je suis obligé de faire avec

    En fait j'ai essayé avec ta solution, mais j'ai exactement le même message d'erreur. Je me demande si je ne dois pas utiliser les CLOB?!
    Mais je ne connais rien là dedans...

    Merci

  6. #6
    Membre chevronné
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    290
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2006
    Messages : 290
    Par défaut
    Bonjour,

    Qu'en est-il avec la fonction to_char ?

  7. #7
    Membre confirmé
    Inscrit en
    Mai 2006
    Messages
    68
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 68
    Par défaut
    Ok, alors finalement j'ai trouvé une solution.

    Une peu plus contraignante que ce que je pensais, mais j'ai utilisé un curseur en PL/SQL. Le curseur modifier lui même le type pour la comparaison.

    Il suffit ensuite de boucler sur les résultats du curseur et faire un simple IF:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if instr(wrec.details, 'TEXTE A RECHERCHER') > 0
    Merci pour les quelques conseils.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 09/06/2009, 14h20
  2. Réponses: 3
    Dernier message: 28/04/2008, 16h23
  3. Réponses: 6
    Dernier message: 04/03/2008, 15h15
  4. select sur un champ de type LONG
    Par ppd dans le forum Langage SQL
    Réponses: 2
    Dernier message: 03/09/2004, 18h19
  5. Valeur par defaut 'True' dans un champ de type bit
    Par Mouse dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 24/03/2003, 15h26

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