Précédent   Forum des professionnels en informatique > Bases de données > MySQL > Installation
Installation Forum d'entraide sur les problèmes liés à l'installation de MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 12/01/2007, 16h54   #1
Invité de passage
 
Inscription : novembre 2006
Messages : 9
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 9
Points : 3
Points : 3
Par défaut character set latin1, encore

Salut à tous,
je sais que le sujet des character seta été abordé des milions de fois, mais j'ai beau chercher, je trouve rien qui résoud mon probleme.
Je vous explique :
un serveur gentoo, avec apache 2.0.58-r2, php 5.1.6-r6, mysql 5.0.26-r1
un LAMP tout ce qu'il y a de plus classique.
Sauf qu'un jour, j'ai voulu installer XOOPS.
Et la, ca a mal tourné : les accents ne passent pas.
Je me dis, bon, la page est en latin1, mysql doit renvoyer du utf8, donc jvai changer la conf et hop.
Mais j'ai eu beau changer my.cnf, mettre latin1 partout, changer l'interclassement de mes bases en latin1_general_ci, rien n'y fait!!!

dans un shell mysql, la commande :
mysql> SHOW VARIABLES like 'character_set_%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+

est ce que ce character_set_system change tout? et si oui comment le changer? et si non que faire?

merci d'avance!
cadbury est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/01/2007, 22h01   #2
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Citation:
est ce que ce character_set_system change tout?
non, rien du tout.
Citation:
et si oui comment le changer?
on ne peut pas. MySQL 5 utilise toujours utf8 comme jeu système.

Citation:
et si non que faire?
nous donner un exemple d'accent qui "ne passe pas"
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/01/2007, 22h31   #3
Invité de passage
 
Inscription : novembre 2006
Messages : 9
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 9
Points : 3
Points : 3
voici un exemple qui ne passe pas :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php
/* table créée avec :
CREATE TABLE `test` (
`nom` VARCHAR( 255 ) NOT NULL ,
`donne` VARCHAR( 255 ) NOT NULL
) ENGINE = MYISAM CHARACTER SET latin1 COLLATE latin1_general_ci;
*/
    mysql_connect("localhost", "lyontraboules", "xxx");
	mysql_select_db("lyontraboules");
	$sql = 'INSERT INTO `test` (`nom`, `donne`) VALUES (\'test\', \'é\');';
	mysql_query($sql);
 
	$sql = 'SELECT * FROM `test` WHERE `nom`=\'test\' LIMIT 1';
	$result = mysql_query($sql);
 
	$row = mysql_fetch_object($result);
 
 ?><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr" lang="fr">
<head>
<meta http-equiv="content-type" content="text/html; charset=ISO-8859-1" />
</head>
<body><?php echo $row->donne; ?></body>
tout est en latin1, normalement il ne devrait pas y avoir de problemes?
pourtant, allez voir le résultat sur http://www.lyontraboules.net/test.php
si on met le charset dans la balise meta a utf8, plus de probleme,
de meme si on fait un
Code :
@mysql_query("SET CHARACTER SET latin1");
sans changer le charset html.

Mais comme je n'ai ni les connaissances ni le temps pour me plonger dans le code de XOOPS, aucune de ces deux solutions ne me conviennent.

voyez vous une solution?
cadbury est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/01/2007, 06h32   #4
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
ce que je constate sur ta page de test, c'est une disparition pure et simple du caractère accentué !

avec ta page PHP, je t'invite à faire le test suivant :

Code :
1
2
3
4
5
6
7
8
9
10
11
<?php
  mysql_connect("localhost", "lyontraboules", "xxx")
    OR die(mysql_error());
  mysql_select_db("lyontraboules");
  $sql = "SELECT CHARSET('é'), _latin1'é', _utf8'é' ; " ;
  $resu = mysql_query($sql) OR die(mysql_error());
  $ligne = mysql_fetch_row($resu) ;
  echo $ligne[0].'<br>' ;
  echo $ligne[1]. ' (caractère '. ord($ligne[1]) . ')<br>' ;
  echo $ligne[2]. ' (caractère '. ord($ligne[2]) . ')<br>' ;
?>
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/01/2007, 12h50   #5
Invité de passage
 
Inscription : novembre 2006
Messages : 9
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 9
Points : 3
Points : 3
effectivement, il a disparu, étrange.

la page est à jour avec ton script :
http://www.lyontraboules.net/test.php
cadbury est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/01/2007, 14h27   #6
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Donc ton script PHP est en UTF-8, même s'il produit une page HTML qui est en Latin-1.

Quant à ton test "INSERT 'é'...", il n'est valable que si tu fais un TRUNCATE TABLE avant. Autrement, il te montre toujours la première ligne de ta table (ce qui, à mon avis, explique la disparition du é).
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/01/2007, 15h53   #7
Invité de passage
 
Inscription : novembre 2006
Messages : 9
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 9
Points : 3
Points : 3
Citation:
Envoyé par Antoun
Donc ton script PHP est en UTF-8, même s'il produit une page HTML qui est en Latin-1.
euh excuse mon ignorance, mais c'est à dire?
cadbury est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/01/2007, 16h04   #8
Invité de passage
 
Inscription : novembre 2006
Messages : 9
Détails du profil
Informations forums :
Inscription : novembre 2006
Messages : 9
Points : 3
Points : 3
je pense avoir résolu le pb!

dans php.ini j'ai décommenté tout ce qui concernai les charset, et mis ISO-8859-1 :
default_charset = "iso-8859-1"
mssql.charset = "ISO-8859-1" (je pense que celui la ne sert a rien)

et la page de test me donne :

latin1
é (caractère 233)
(caractère 0)

merci de votre aide
cadbury est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 19h33.


 
 
 
 
Partenaires

Hébergement Web