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

Shell et commandes GNU Discussion :

Encodage MySQL


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Webmaster
    Inscrit en
    Novembre 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Novembre 2015
    Messages : 12
    Par défaut Encodage MySQL
    Bonjour,

    J'ai créé un petit script ssh pour automatiser un update dans un champ d'une table mysql...cependant j'ai un problème d'accent

    Mon script:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    #!/bin/bash
    # on ajoute 7jours à la date en cours
    NEW_expration_DATE=$(date +'%m/%d/%Y' -d '+7 days')
    datelibel=$(date +'%d %B' -d '+7 days')
    # on upgrade en db
    mysql -h localhost -uadmin -p`cat /etc/psa/.psa.shadow` -e "UPDATE MABD.ps_category_lang SET description = 'JUSQU\'AU $datelibel' WHERE ps_category_lang.id_category = 298 AND ps_category_lang.id_shop = 1 AND ps_category_lang.id_lang = 1;";
    Tout fonctionne bien sauf que j'ai testé +170 jours (donc février).. le script me remonte dans la table :
    JUSQU'AU 27 février

    si un âme charitable peut me venir en aide :-) merci par avance

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 102
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 102
    Par défaut
    Citation Envoyé par Gribouille92 Voir le message
    JUSQU'AU 27 février
    Je ne suis pas spécialiste, mais, manifestement, la chaîne stockée dans la variable "datelibel" est codée en UTF-8.
    Tu peux le vérifier en insérant un echo "${datelibel}" | od -bc qui devrait afficher "303" et "251":
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    echo "${datelibel}" | od -bc
    0000000   303 251
               é  **
    Ensuite, tu insères cette chaîne telle quelle dans la base.
    Il me semble me rappeler qu'il y a un paramètre dans mysql qui précise le système utilisé pour recevoir et stocker les chaines.
    Probablement que, dans ton cas, il s'agit de iso-8859-1 pour lequel "303 251" correspond aux caractères "Ã" et "©".

    Il y a plusieurs solutions à ton problème:
    - changer le locale du script pour te mettre en iso-8859-1
    - changer l'encodage de la base pour la mettre en utf-8
    - convertir la chaine:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    datelibel=$(date +'%d %B' -d '+7 days' | iconv -f UTF-8 -t ISO_8859-1)

  3. #3
    Membre averti
    Homme Profil pro
    Webmaster
    Inscrit en
    Novembre 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Novembre 2015
    Messages : 12
    Par défaut
    MERCI !!! vivement pour ton analyse, c'est corrigé avec la conversion de chaîne.
    Merci encore de ton aide :-))))

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

Discussions similaires

  1. Problème Encodage mysql/php
    Par yuyu599 dans le forum Langage
    Réponses: 3
    Dernier message: 15/04/2011, 18h11
  2. problème encodage mysql
    Par karybluedoor dans le forum Requêtes
    Réponses: 0
    Dernier message: 08/12/2010, 09h21
  3. [MySQL] Mauvais encodage MySQL
    Par blueice dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 06/08/2008, 12h39
  4. Problème d'encodage mysql
    Par nicolou dans le forum Requêtes
    Réponses: 7
    Dernier message: 08/06/2006, 17h01
  5. [ENCODAGE] MySQL Au secours
    Par hisy dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 30/03/2006, 16h26

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