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 :

Requêtes SQL sur une BD Oracle


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Mars 2007
    Messages
    74
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2007
    Messages : 74
    Par défaut Requêtes SQL sur une BD Oracle
    Bonjour,

    Je souhaiterais effectuer des requêtes SQL sur un table Oracle. Le soucis c'est qu'Oracle n'accepte pas certains caractères spéciaux. Je m'explique.

    Ma requête est la suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT * FROM table_1 WHERE column_id = 'toto:' 
    AND column_concept IN ( SELECT column_concept FROM table_2
                                       WHERE tata LIKE '\un\20. deux\10. trois\quatre\%')
    A priori les caractères '\' et '%' ne sont pas reconnus.

    J'ai déjà essayé ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT * FROM table_1 WHERE column_id = 'toto:' 
    AND column_concept IN ( SELECT column_concept FROM table_2
                                       WHERE replace(tata,'\','.') LIKE '.un.20. deux.10. trois.quatre.%')
    Ou cela

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT * FROM table_1 WHERE column_id = 'toto:' 
    AND column_concept IN ( SELECT column_concept FROM table_2
                                       WHERE tata LIKE '\\un\\20. deux\\10. trois\\quatre\\%')
    Mais aucun succès. Je suis un peu embarrassée et désespérée. En utilisant Oracle Sql Developer, ou DbVizualiser, ma requête fonctionne parfaitement.
    Mais lorsque je l'importe sous Talend (quand je quitte l'univers oracle), rien ne va plus. Auriez vous des pistes?

    D'avance merci.

  2. #2
    Membre très actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2011
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2011
    Messages : 146
    Par défaut
    Bonjour,

    Pas de problème à priori :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    WITH TEST
    AS (SELECT  '\un\20. deux\10. trois\quatre\cinq' as CHAMP1 FROM DUAL)
    SELECT * 
    FROM TEST
    WHERE CHAMP1 like '\un\20. deux\10. trois\quatre\%'
    Edit : pas vu la partie "Talend" de ta question, donc le probleme vient de Talend et non pas d'oracle à priori.

  3. #3
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Mars 2007
    Messages
    74
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2007
    Messages : 74
    Par défaut
    Citation Envoyé par ORA-007 Voir le message
    Bonjour,

    Pas de problème à priori :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    WITH TEST
    AS (SELECT  '\un\20. deux\10. trois\quatre\cinq' as CHAMP1 FROM DUAL)
    SELECT * 
    FROM TEST
    WHERE CHAMP1 like '\un\20. deux\10. trois\quatre\%'
    Bonjour,

    Oui la requête est correcte depuis un univers "Oracle". Mais si je veux interroger une base Oracle depuis "Talend" par exemple pour exporter le résultat dans un fichier ou table MySql ça passe plus...

    Saurais tu comment gérer ces caractères spéciaux?

  4. #4
    Membre très actif
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2011
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2011
    Messages : 146
    Par défaut
    Bonjour,

    une solution serait pour toi de passer par le code ASCII des caractères spéciaux.

    Exemple oracle :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select chr(92) from dual
    Je pense que tu devrais aller plutôt ici :

    http://www.developpez.net/forums/f97...ce/etl/talend/

Discussions similaires

  1. Problème de requête Access sur une table Oracle
    Par Poulki dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 31/01/2008, 16h57
  2. Requête SQL sur une base HF
    Par PimSaVie dans le forum WinDev
    Réponses: 6
    Dernier message: 02/01/2008, 08h28
  3. [SQL] Problème de requête SQL sur une condition avec OR
    Par vinzginz dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 12/10/2007, 15h31
  4. Réponses: 4
    Dernier message: 27/12/2006, 21h53

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