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

PHP & Base de données Discussion :

Encodage et utf


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de PIEPLU
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    507
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 507
    Par défaut Encodage et utf
    Bonjour,

    J'ai un site en utf-8 et une table avec une structure en interclassement 'utf8_general_ci'.

    J'insère les chaines de caractères avec mysql_real_escape_string et les entiers avec intval.

    Je ne comprend pas pourquoi lorsque j'ai des accents, ils sont insérés bizarrement.

    Voici un exemple, j'ai voulu insérer "16 la haût", et quand je regarde dans la table, dans phpmyadmin, j'ai "16 la haût"

    Que dois je faire pour insérer correctement ?

    Merci

  2. #2
    Expert confirmé Avatar de CosmoKnacki
    Homme Profil pro
    Justicier interdimensionnel
    Inscrit en
    Mars 2009
    Messages
    2 986
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente Maritime (Poitou Charente)

    Informations professionnelles :
    Activité : Justicier interdimensionnel

    Informations forums :
    Inscription : Mars 2009
    Messages : 2 986
    Par défaut
    L'interclassement (ou collation) n'a strictement aucune incidence sur le codage de caractère utilisé par MySQL, l'interclassement n'intervient que dans la manière dont MySQL va faire un tri alphabétique.

    Tu peux en revanche demander explicitement un codage en utf8 pour un champ à la création d'un table:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    CREATE TABLE matable (
      monchamp CHAR(50) CHARACTER SET utf8
    )

    ou pour toute la table:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    CREATE TABLE matable (
      monchamp1 CHAR(50),
      monchamp2 CHAR(50)
    ) DEFAULT CHARSET=utf8;

    Tu peux également jeter un œil dans le fichier my.conf pour voir quelles sont les valeurs pour default-character-set et character-set-server.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    => Passez à l'UTF-8 sans manquer une étape

    Si ça ne suffit pas, MONTRE-nous ton CODE, sur une page SIMPLE (simplifiée), qu'on voit comment :
    • tu affiches la page (entête)
    • tu te connectes à la base (en masquant tes paramètres, évidemment !)
    • tu récupères des données
    • tu les affiches.

    Bref. Si tu as bien suivi toutes les étapes sus-mentionnées.

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 225
    Par défaut
    Avec PDO, je met sa dans mon script d'accès à la bdd comme sa j'ai pas de problème:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $connexion->query("SET CHARACTER SET utf8");

  5. #5
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 418
    Par défaut
    @totot Si c'est dans le script d'accès (valable pour toutes les requêtes) il serait plus intéressant d'utiliser MYSQL_ATTR_INIT_COMMAND dans le constructeur de pdo
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    new PDO(..., ..., ..., array(PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'))
    et pour les versions récentes de php on peut passer le charset comme dernier argument du dns
    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
    $dsn = 'mysql:dbname=testdb;host=127.0.0.1;charset=UTF8';
    $user = 'dbuser';
    $password = 'dbpass';
     
    $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    $pdo_options[PDO::ATTR_EMULATE_PREPARES] = false;
     
    try
    {
        $dbh = new PDO($dsn, $user, $password, $pdo_options);
    }
    catch (PDOException  $e)
    {
        echo $e->getMessage();
    }

Discussions similaires

  1. Encodage : Conversion UTF-8 vers ISO-8859-?
    Par polo54 dans le forum Général Java
    Réponses: 6
    Dernier message: 26/06/2007, 19h10
  2. Réponses: 1
    Dernier message: 24/04/2007, 18h19
  3. encodage en UTF-8
    Par ChBoc dans le forum Servlets/JSP
    Réponses: 7
    Dernier message: 26/10/2006, 04h28
  4. Problème d'encodage en UTF-8
    Par navis84 dans le forum Langage
    Réponses: 5
    Dernier message: 29/08/2006, 11h19
  5. [C#] Encodage en UTF et ASCII
    Par Machjaghjolu dans le forum C#
    Réponses: 3
    Dernier message: 11/11/2005, 02h19

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