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

PostgreSQL Discussion :

[PostgreSQL 8.3] Problème d'encodage de base


Sujet :

PostgreSQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 144
    Points : 45
    Points
    45
    Par défaut [PostgreSQL 8.3] Problème d'encodage de base
    Bonjour,
    Je suis sous Debian avec une base de données PostgreSQL 8.3, sous pgAdminIII, avec un serveur local.
    Je souhaiterais créer une base de données avec l'encodage LATIN9. Or lorsque je crée une base LATIN9, j'ai l'erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Une erreur s'est produite :
     
    ERREUR:  l'encodage LATIN9 ne correspond pas à la locale fr_FR.UTF-8 du serveur
    DETAIL:  Le paramètre LC_CTYPE du serveur nécessite l'encodage UTF8.
    En ligne de commande cela n'a pas fonctionné non plus. Apparemment il faut changer l'encodage du serveur local. Quelqu'un connaîtrait-il la procédure ?
    Vous remerciant d'avance.
    Cordialement.

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    Par défaut
    Le plus simple est d'utiliser postgresql 8.4 qui permet d'avoir un encodage différent par base.
    En 8.3 il faut refaire la phase d'initialisation du cluster (initdb) avec l'option --locale
    Sauf qu'avec debian en principe on n'utilise pas directement initdb mais les outils du package debian: pg_createcluster, pg_upgradecluster et pg_dropcluster.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 144
    Points : 45
    Points
    45
    Par défaut
    Bonjour,
    J'ai essayé les 2 méthodes.
    En faisant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    pg_createcluster --locale=LATIN9 8.3 main
    j'ai l'erreur : initdb : nom de locale invalide (« LATIN9 »)

    Et en installant PostgreSQL 8.4, j'ai le message suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    postgresql-8.4:
      Dépend*: libc6 (>=2.11) mais 2.7-18lenny4 doit être installé
     Dépend*: libgssapi-krb5-2 mais ne doit pas être installé
     Dépend*: libkrb5-3 mais ne doit pas être installé
      Dépend*: libpq5 (>=8.4~0cvs20090328) mais 8.3.11-0lenny1 doit être installé
      Dépend*: libssl0.9.8 (>=0.9.8m-1) mais 0.9.8g-15+lenny8 doit être installé
      Dépend*: libxml2 (>=2.7.4) mais 2.6.32.dfsg-5+lenny1 doit être installé
     Dépend*: postgresql-client-8.4 mais ne doit pas être installé
      Dépend*: postgresql-common (>=109~) mais 94lenny1 doit être installé
    Je suis sous Debian Lenny.
    Si vous pouviez m'aider pour l'une ou l'autre méthode ?

  4. #4
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    Par défaut
    pg_createcluster --locale=LATIN9 8.3 main
    LATIN9 n'est pas une locale, c'est juste un encodage.
    Pour avoir la liste des locales du système faire la commande shell:
    Il faudrait qu'il y ait dans les résultats un nom du genre
    fr_FR@euro ou bien fr_FR.iso885915@euro

    Si elles n'y sont pas, ce qui est possible pour un système en UTF8, il faudrait les ajouter avec la procédure standard debian.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 144
    Points : 45
    Points
    45
    Par défaut
    Merci Estofilo, j'ai réussi à créer ma base en LATIN9, en suivant ta procédure.

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

Discussions similaires

  1. [QtSql] De QTextEdit à une base PostgreSQL : problème d'encodage
    Par vince5962 dans le forum PyQt
    Réponses: 5
    Dernier message: 09/07/2013, 14h35
  2. problème de connexion à une base postgresql
    Par QAYS dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 16/10/2008, 11h26
  3. export de base, problème d'encodage
    Par Gilles F dans le forum SQL Procédural
    Réponses: 0
    Dernier message: 08/10/2007, 16h17
  4. problème d'encodage postgresql
    Par Qamalito dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 13/08/2007, 09h36
  5. [MySQL] Problème d'encodage / transfert de base de données
    Par Theberge43 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 30/01/2007, 18h21

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