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

Langage SQL Discussion :

Supprimer les espaces du champ ramené


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Femme Profil pro
    Conseiller de gestion
    Inscrit en
    Août 2017
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Conseiller de gestion
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2017
    Messages : 25
    Points : 22
    Points
    22
    Par défaut Supprimer les espaces du champ ramené
    Bonjour,

    Pour créer une requête webi liant 2 univers, je dois supprimer les espaces du champ de l'univers 1

    univers 1 : O_AFFECTATION.ANNEE=2017 (avec des espaces derrière)
    univers 2 : année =2017 (sans espace)

    J'ai vu qu'il existait une fonction TRIM. Mais j'ai un message d'erreur Peut être que je ne l'utilise pas comme il faut ?
    Dans le fichier joint le message d'erreur et l'ajout de trim (ligne jaune)


    Pourriez-vous m'aider SVP ?
    Un grand merci

    Clémence
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 197
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 197
    Points : 12 772
    Points
    12 772
    Par défaut
    Bonjour,
    Citation Envoyé par Clemence01 Voir le message
    Dans le fichier joint le message d'erreur et l'ajout de trim (ligne jaune)
    Pourriez-vous m'aider SVP ?
    Un grand merci

    Clémence
    Bonjour,
    Peux-tu nous mettre directement dans le message la requête et le message d'erreur ?
    Il nous faut aussi le SGBD utilisé, certaines fonctions n'étant pas forcément les mêmes de l'un à l'autre.

    Tatayo.

  3. #3
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 133
    Points : 38 555
    Points
    38 555
    Billets dans le blog
    9
    Par défaut
    Le message d'erreur ne mentionne pas que c'est la fonction TRIM qui pose problème, la syntaxe est correcte sur ce point
    Par contre, la requête est mal présentée, les jointures ne sont pas normalisées et du coup c'est difficile à relire
    Comme il n'y a aucun alias de table et un grand nombre de tables, il est fort possible que le problème vienne de là (nom de colonne ambigu).

  4. #4
    Membre à l'essai
    Femme Profil pro
    Conseiller de gestion
    Inscrit en
    Août 2017
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Conseiller de gestion
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2017
    Messages : 25
    Points : 22
    Points
    22
    Par défaut
    Bonjour,

    Voici le message d'erreur

    "Une erreur de base de données s'est produite.
    Le message d'erreur est le suivant : [Microsoft] [OBDC SQL Server Driver] [SQL Server] statements could not be prepared (WIS 10901)"


    Voici la requête (sur les 2 1ères lignes, j'ai juste ajouté TRIM( )
    Merci !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    SELECT DISTINCT
    TRIM(O_AFFECTATION.ANNEE), 
    TRIM(O_AFFECTATION.TYBUDGET),
      C_CREDIText.CDCRDTSSCH,
      O_COMMANDE.CDBONCDE,
      O_OPERATION.NUOPER,
      O_COMMANDE.LBCMD,
      PF_EQLOCALISATION.CDCOIM,
      PP_COMPLEXE_UGF.NMCOIM,
      O_OPERATION.nuopersuipar,
      F_PERSO_SUIVI_OPERATION.NMPERS,
      F_PERSO_SUIVI_OPERATION.NUATEL,
      O_COMMANDE.MTATTRIB,
      O_COMMANDE.NUFOUR,
      F_SOUS_TRAITANT.RSFOUR,
      O_INTERVENTION.NUOPER + '-' + O_INTERVENTION.NUINTE,
      O_INTERVENTION.DTINTESAIS,
      O_COMMANDE.DTEMISSBC,
      O_INTERVENTION.NUINTESUIPAR,
      F_PERSONNEL_SPint.NUATEL,
      F_PERSONNEL_SPint.NMPERS+' '+F_PERSONNEL_SPint.PNPERS,
      O_COMMANDE.NUENGAG,
      O_INTERVENTION.TYINTE,
      O_INTERVENTION.TYCRDT,
      O_COMMANDE.FGETAT, 
      O_AFFECTATION.TYCRDT,
      N_CREDIT_NATUREext.CDNATURECRDT,
     
      O_AFFECTATION.CDVERSION
    FROM
      O_INTERVENTION,
      O_OPERATION,
      PF_EQLOCALISATION,
      F_EQUIPEMENT,
      O_COMMANDE,
      O_AFFECTATION,
      PP_COMPLEXE  PP_COMPLEXE_UGF,
      F_FOURNISSEUR  F_SOUS_TRAITANT,
      C_CREDIT  C_CREDIText,
      C_CREDIT_VALIDE  C_CREDIT_VALIDEext,
      F_PERSONNEL  F_PERSO_SUIVI_OPERATION,
      F_PERSONNEL  F_PERSONNEL_SPint,
      N_CREDIT_NATURE  N_CREDIT_NATUREext
    WHERE
      ( O_INTERVENTION.NUOPER=O_OPERATION.NUOPER  )
      AND  ( F_EQUIPEMENT.NUEQUI=O_OPERATION.NUEQUI and F_EQUIPEMENT.TYEQUI=O_OPERATION.TYEQUI  )
      AND  ( O_INTERVENTION.NUINTE=O_COMMANDE.NUINTE and O_INTERVENTION.NUOPER=O_COMMANDE.NUOPER  )
      AND  ( O_AFFECTATION.NUOPER=O_COMMANDE.NUOPER and O_AFFECTATION.NUINTE=O_COMMANDE.NUINTE  )
      AND  ( PP_COMPLEXE_UGF.CDCOIM=PF_EQLOCALISATION.CDCOIM  )
      AND  ( PF_EQLOCALISATION.TYEQUI=F_EQUIPEMENT.TYEQUI and PF_EQLOCALISATION.CDEQUI=F_EQUIPEMENT.NUEQUI  )
      AND  ( F_SOUS_TRAITANT.NUFOUR=O_COMMANDE.NUFOUR  )
      AND  ( C_CREDIT_VALIDEext.NUDRGE=C_CREDIText.NUDRGE and C_CREDIT_VALIDEext.NUSDRG=C_CREDIText.NUSDRG and C_CREDIT_VALIDEext.CDARTB=C_CREDIText.CDARTB and C_CREDIT_VALIDEext.TYBUDGET=C_CREDIText.TYBUDGET and C_CREDIT_VALIDEext.CDVERSION=C_CREDIText.CDVERSION and C_CREDIT_VALIDEext.ANCRDV=C_CREDIText.ANCRDT  )
      AND  ( C_CREDIT_VALIDEext.CDARTB=O_AFFECTATION.CDARTB and C_CREDIT_VALIDEext.CDVERSION=O_AFFECTATION.CDVERSION and C_CREDIT_VALIDEext.NUDRGE=O_AFFECTATION.NUDRGE and C_CREDIT_VALIDEext.NUSDRG=O_AFFECTATION.NUSDRG and C_CREDIT_VALIDEext.TYBUDGET=O_AFFECTATION.TYBUDGET and C_CREDIT_VALIDEext.ANCRDV=O_AFFECTATION.ANNEE  )
      AND  ( O_OPERATION.nuopersuipar=F_PERSO_SUIVI_OPERATION.NUPERS  )
      AND  ( O_INTERVENTION.NUINTESUIPAR=F_PERSONNEL_SPint.NUPERS  )
      AND  ( C_CREDIText.CDNATURECRDT=N_CREDIT_NATUREext.CDNATURECRDT  )
      AND  
      (
       O_OPERATION.DTOPERDEBO  >=  @prompt('EntréeDATE PREVISION DEBUT:','D','OPERATION\DATE PREVISION DEBUT',Mono,Free,Persistent,,User:0)
       AND
       O_INTERVENTION.TYINTE  =  'S'
       AND
       O_INTERVENTION.TYCRDT  =  'F'
       AND
       O_COMMANDE.FGETAT  IN  ( 'M','I','V','A','R'  )
      )

  5. #5
    Membre à l'essai
    Femme Profil pro
    Conseiller de gestion
    Inscrit en
    Août 2017
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Conseiller de gestion
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2017
    Messages : 25
    Points : 22
    Points
    22
    Par défaut
    Bonjour,

    Le SQL s'est créé automatiquement lorsque j'ai créé une requête webi.
    Il fonctionne sans problème sans mon intervention manuelle pour ajouter TRIM.
    C'est seulement lorsque j'ajoute TRIM sur 2 champs que j'obtiens ce message d'erreur

    Merci !!!

    Clémence

  6. #6
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    bonjour,


    Et en donnant un nom aux colonnes ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT DISTINCT
    TRIM(O_AFFECTATION.ANNEE) AS ANNEE, 
    TRIM(O_AFFECTATION.TYBUDGET) AS TYBUDGET,
    ...

  7. #7
    Membre à l'essai
    Femme Profil pro
    Conseiller de gestion
    Inscrit en
    Août 2017
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Conseiller de gestion
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2017
    Messages : 25
    Points : 22
    Points
    22
    Par défaut
    Bonjour,

    Merci pour votre bonne idée.
    J'ai bien essayé de remplacer par votre suggestion mais le message d'erreur persiste à l'ajout de TRIM...

    D'autres idées ?
    Un grand merci

  8. #8
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    quelle est votre version de SQL Server ? la fonction TRIM est récente (version 2017 je crois)

    essayez
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT DISTINCT
    RTRIM(LTRIM(O_AFFECTATION.ANNEE)) AS ANNEE, 
    RTRIM(LTRIM(O_AFFECTATION.TYBUDGET)) AS TYBUDGET,
    ...
    Autre conseil plus global : dans ce genre de cas, testez votre requête dans management studio. L'erreur sera alors beaucoup plus explicite.

  9. #9
    Membre à l'essai
    Femme Profil pro
    Conseiller de gestion
    Inscrit en
    Août 2017
    Messages
    25
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Conseiller de gestion
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2017
    Messages : 25
    Points : 22
    Points
    22
    Par défaut
    Je ne connais malheureusement pas la version. J'accède à ce SQL via des requêtes WEBI pour lesquelles le code se crée automatiquement (je ne vois qu'une fenêtre de code).
    Peut être est-ce un problème de sécurité sur l'univers en particulier qui ne permettrait pas les modifications.
    Je vais essayer de faire différemment : ajouter des espaces sur le champ du 2ème univers.

    Je vous remercie en tout cas pour votre aide et le temps consacré pour m'aider dans la résolution de cette difficulté.

    Bonne journée

    Clémence

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

Discussions similaires

  1. Supprimer les espaces à la fin d'un champ
    Par Taxan dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 29/08/2013, 16h23
  2. Réponses: 3
    Dernier message: 19/08/2009, 18h25
  3. Supprimer les espaces dans un champ
    Par leloup84 dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 02/02/2009, 17h08
  4. Supprimer les espaces en début et fin sur un ensemble de champs
    Par Olivier Regnier dans le forum Langage
    Réponses: 7
    Dernier message: 14/11/2007, 20h06
  5. Réponses: 9
    Dernier message: 06/11/2007, 12h36

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