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

Administration Oracle Discussion :

CHARSET - Cas du caratère ½


Sujet :

Administration Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné Avatar de Wurlitzer
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 469
    Par défaut CHARSET - Cas du caratère ½
    Bonsoir,

    Mon but est d'insérer le caractère ½ et bien sur de pouvoir le lire.

    Pour commencer, je tiens a préciser que j'ai lu le tuto Evitez les erreurs de conversion grâce aux NLS qui est très interessant mais que je n'ai pas réussi a y trouver la solution a mon problème.

    J'ai donc une base Oracle 8i sous Unix avec un charset à WE8ISO8859P15.

    Si je force le CHARSET coté UNIX avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    export NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P15
    Je peux sous sqlplus (UNIX) insérer et lire mon caractère ½

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    SQL> create table test ( CLIENT VARCHAR2(10) , COL VARCHAR2(2));
    Table created.
     
    SQL> SELECT '½' FROM DUAL
      2  /
    -
    ½
     
    SQL> INSERT INTO TEST ( CLIENT , COL ) VALUES ('UNIX', '½') ;
    1 row created.
    Coté Windows GUI j'ai le code page 1252 donc je fixe
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    set NLS_LANG=AMERICAN_AMERICA.WE8MSWIN1252
    avant de lancer dans la meme fenete DOS sqlplusw

    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
     
    SQL> SELECT '½' FROM DUAL;
    -
    ¿
     
      1*  INSERT INTO TEST ( CLIENT , COL ) VALUES ('WIN', '½')
    SQL> /
    1 row created.
     
    SQL> SELECT CLIENT, COL, RAWTOHEX(COL) FROM TEST;
     
    CLIENT     COL          RAWT
    ---------- --            ----
    UNIX       "carré noir"  BD
    WIN        ¿               BF
    alors que sous UNIX

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT CLIENT, COL, RAWTOHEX(COL) FROM TEST;
     
    CLIENT     COL RAWT
    ---------- --   ----
    UNIX       ½     BD
    WIN        ¿      BF
    D'après ce que j'ai vu BD est bien la valeur hexa du caractère ½.

    Vous comprenez pourquoi je n'arrive ni à insérer ni a lire le ½ coté windows GUI ?

    Merci de votre aide.

  2. #2
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Par défaut
    Pour afficher la représentation binaire d'une colonne caractère, il vaut mieux utiliser la fonction DUMP:

    Et sous Windows, il vaut mieux utiliser sqlplus.exe (avec NLS_LANG=.WE8PC850) que sqlplusw.exe.

    Pour votre problème spécifique, le caractère ½ existe dans le ISO 8859-1 et dans le MS 1252 mais n'existe pas dans le ISO 8859-15

    Sous Unix, il semble que cela marche car si la partie jeu de caractère de NLS_LANG est identique au jeu de la base, Oracle ne vérifie pas le code binaire et ne convertit les caractères ni entrée ni en sortie.

  3. #3
    Membre chevronné Avatar de Wurlitzer
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 469
    Par défaut
    Merci pour cette réponse rapide.

    Si je comprends bien c'est foutu puisque je suis en WE8ISO8859P15 et que ½ n'existe pas dans cette page de caratère.

    Mais pourquoi est ce que cela marche quand je suis avec mon client UNIX ?

    Est ce parce que je fais la meme erreur en écriture et en lecture et donc que mon ½ est en realité auter chose dans la base ?

    Une petite question subsidaire. Ou est que je peux trouver la description de toutes les pages de code Oracle ? Il m'en faudrait une avec le ½ et bien sur l'euro....

  4. #4
    Membre Expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Par défaut
    Mais pourquoi est ce que cela marche quand je suis avec mon client UNIX ?
    Sous Unix, il semble que cela marche car si la partie jeu de caractère de NLS_LANG est identique au jeu de la base, Oracle ne vérifie pas le code binaire et ne convertit les caractères ni entrée ni en sortie et laisse le système d'exploitation afficher les caractères.

    Une petite question subsidaire. Ou est que je peux trouver la description de toutes les pages de code Oracle ? Il m'en faudrait une avec le ½ et bien sur l'euro....
    Oracle ne définit pas les jeux de caractères mais utilise les jeux de caractères standards définis par l'ISO, Unicode ou Microsoft et les renomme. Il faut retrouver le nom original en supprimant en général les 3 premiers caractères du nom Oracle et ensuite faire une recherche sur le web.

  5. #5
    Membre chevronné Avatar de Wurlitzer
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 469
    Par défaut
    Encore une fois merci,

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

Discussions similaires

  1. [XSLT][JSP] solution technique pour cas typique
    Par Alix_10 dans le forum XSL/XSLT/XPATH
    Réponses: 3
    Dernier message: 04/09/2006, 13h09
  2. Réponses: 2
    Dernier message: 05/01/2004, 11h23
  3. [SYBASE] INFO AU CAS OU...
    Par Zeo_BO dans le forum Sybase
    Réponses: 6
    Dernier message: 29/07/2003, 12h44
  4. [corba] débutant : dans quels cas l'utiliser
    Par jmturc dans le forum CORBA
    Réponses: 2
    Dernier message: 10/10/2002, 08h58

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