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 :

problème d'espace à la fin d'une requête


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2007
    Messages : 46
    Par défaut problème d'espace à la fin d'une requête
    Bonjour,
    j'ai un problème de requête.
    Si je mets un espace à la fin du mot recherché il l'ignore. ce que je ne veux pas.
    Quand c'est au début ou au milieu il y a pas de problème.
    Par exemple le select suivant (Pierre suivi d'un espace) renvoie bien le nom.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    	SELECT nom FROM personne WHERE per_c_user = : 'Pierre ';
    Celui-ci (espace avant Pierre) ne le trouve pas
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    	SELECT nom FROM personne WHERE per_c_user = : ' Pierre';
    parce que dans la base Pierre est écrit sans espace.
    Ce que je veut c'est l'inverse de Trim c'à.d s'il y a un espace dans ma requête et pas dans la base il ne faut pas qu'il me trouve la personne cherché. En gros : Pierre n'est pas égale à Pierre+espace.

  2. #2
    Membre Expert Avatar de fatsora
    Profil pro
    Inscrit en
    Février 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 1 103
    Par défaut
    Bonjour,

    as tu fais un desc de la table personne

    Car il semble que tu soit en CHAR et non VARCHAR

    ce qui explique ce genre de comportement.

    Si tu as la main sur tes tables ,
    tu peux recréer une autre table avec trim(NOM) et colonne VARCHAR

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    create table PERS as select trim(name),... from PERSONNE
    ou faire un changement de la colonne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    alter table PERSONNE modify NOM varchar2(XXX) ;
     
    update test set NAME=trim(NAME) ;

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2007
    Messages : 46
    Par défaut
    Effectivement avec VarChar2 il n'y a pas de problème. Il reconnait bien les espaces.
    Le problème est que je n'ai pas le droit de changer le type de la colonne.

  4. #4
    Membre Expert Avatar de fatsora
    Profil pro
    Inscrit en
    Février 2006
    Messages
    1 103
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 1 103
    Par défaut
    OK ,

    Qu'est ce que tu as le droit de faire ?
    creer un table ? une vue matérialisée ,une vue ? ou rien de tout ca ?

    Peux tu demander a une autre personne , ou autre service de faire pour toi
    ce changement ?

  5. #5
    Membre chevronné

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    507
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 507
    Par défaut
    Une idée à tester. Tu peux comparer en remplaçant les espaces par un autre caractère.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT nom FROM personne WHERE REPLACE(per_c_user,' ',':') = REPLACE('Pierre ',' ',':');

  6. #6
    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
    Autant faire simple et trimer la colonne de la table dans le filtre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT nom
    FROM personne
    WHERE TRIM(per_c_user) = :user;
    Pour améliorer les performances (si c'est un soucis) vous pouvez créer un index sur trim(per_c_user).

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    46
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juin 2007
    Messages : 46
    Par défaut Résolu
    Citation Envoyé par GoLDoZ Voir le message
    Une idée à tester. Tu peux comparer en remplaçant les espaces par un autre caractère.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT nom FROM personne WHERE REPLACE(per_c_user,' ',':') = REPLACE('Pierre ',' ',':');
    C'est exactement ce que je cherchais. Ca marche.

    trimer la colonne de la table dans le filtre ne résout pas mon problème parce que je ne veux pas enlever les espaces mais ce que je veux c'est comparé la chaîne de caractères caractère par caractère avec les espaces : cas des nom composé (De Gaule).

    Merci pour tous

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

Discussions similaires

  1. [SQL] Problème pour récupérer le resultats d'une requête
    Par -Neo- dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 14/06/2007, 10h50
  2. Réponses: 7
    Dernier message: 21/05/2007, 16h28
  3. Réponses: 2
    Dernier message: 04/04/2007, 15h51
  4. [MySQL] problème de récupération des données d'une requête
    Par maniaco_jazz dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 19/02/2007, 12h12
  5. récupération du message à la fin d'une requête
    Par beab1802 dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 21/04/2006, 22h33

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