DotClear 1 à 2 : UTF8

Consultez la formation au référencement naturel Google de WebRankInfo / Ranking Metrics

FloBaoti
WRInaute passionné
WRInaute passionné
 
Messages: 684
Inscription: Dim Avr 30, 2006 18:42

DotClear 1 à 2 : UTF8

Message le Lun Juil 14, 2008 13:59

Salut à tous,

Alors je rencontre un petits souci dans la migration de Dotclear 1 à Dotclear 2.

Il s'agit de la gestion de l'UTF8.

Dans la version 1, les tables MySQL sont définies en latin1, mais Dotclear y stocke de l'utf8 à l'intérieur (grâce à un plugin je crois, ou je ne sais plus quoi).

Dans la version 2, l'UTF8 est géré au niveau de la base.

Donc dans les tables de la version 1, j'ai des données dans ce genre:
Société

(accents codés en UTF8 dans un champ non-UTF8, mais ça passe à l'affichage final puisque le charset HTML est UTF8)

Or dans la version 2, les champs étant définis en "utf8_bin", les caractères spéciaux sont gérés en interne, et donc dans PHPMyAdmin on voit les accents de manière correcte.

La question est: comment passer les champs de la version 1 à la version 2, sans passer par PHP (que ça soit MySQL qui gère la transformation des champs).

En clair, il me faudrait un équivalent à "utf8_decode" de PHP, mais sous MySQL (version 5).

J'ai essayé CONVERT et CAST sans grand succès... :cry:

Quelqu'un aurait-il une idée ?

Merci par avance!! :lol:

P.S.: en plus de ça, on passe de MyISAM à InnoDB, mais je ne pense pas que ça change quelque chose dans mon histoire.


julienr
WRInaute passionné
WRInaute passionné
 
Messages: 866
Inscription: Mar Aoû 05, 2003 14:49

Message le Lun Juil 14, 2008 14:46

salut,
jamais essayé mais ceci peu peut etre faire l'affaire:

ALTER TABLE tbl_name CONVERT TO CHARACTER SET charset_name;

http://dev.mysql.com/doc/refman/5.0/en/alter-table.html#id3240613

a+

FloBaoti
WRInaute passionné
WRInaute passionné
 
Messages: 684
Inscription: Dim Avr 30, 2006 18:42

Message le Lun Juil 14, 2008 14:59

Hello,

Tel quel apparemment ça ne me change rien. Ça change effectivement l'interclassement des champs, mais ne convertit pas les données :cry:

Merci quand même... :lol:


julienr
WRInaute passionné
WRInaute passionné
 
Messages: 866
Inscription: Mar Aoû 05, 2003 14:49

Message le Lun Juil 14, 2008 15:07

ok, quand tu dis tu as essayé, tu peux donner les lignes sql ?!
car à parcourir rapidement la doc
convert et cast en mysql5 semble être fait pour cela :
http://dev.mysql.com/doc/refman/5.0/en/charset-convert.html

FloBaoti
WRInaute passionné
WRInaute passionné
 
Messages: 684
Inscription: Dim Avr 30, 2006 18:42

Message le Lun Juil 14, 2008 15:10

J'ai suivi exactement la doc... par exemple:

Code: Tout sélectionner
INSERT INTO v2_category (SELECT cat_id, \'generatix\', CONVERT(cat_libelle USING utf8), CONVERT(cat_libelle_url USING utf8), CONVERT(cat_desc USING utf8), cat_ord FROM blog_categorie);


Le souci est que la table initiale (blog_categorie par exemple) est définie en latin1, mais contient des données UTF8. Donc MySQL tente de me convertir du latin1 en UTF8.

Et donc là je me retrouve avec les caractères spéciaux de cette manière:
Société
(comme sur Dotclear 1 alors que ça ne devrait pas être le cas)


julienr
WRInaute passionné
WRInaute passionné
 
Messages: 866
Inscription: Mar Aoû 05, 2003 14:49

Message le Lun Juil 14, 2008 17:10

oki compris (pour l'avoir tester aussi) et convert ne pourra pas fonctionner avec de l'utf8 ds de l'iso car il ne fait que réencoder une deuxième fois l'accent (déjà sous forme de 2 caractères)
je passe donc mon tour, bon courage


UsagiYojimbo
WRInaute accro
WRInaute accro
 
Messages: 5185
Inscription: Mer Nov 23, 2005 10:38

Message le Lun Juil 14, 2008 17:38

Je veux peut-être dire une grosse connerie, mais j'ai eu un problème de ce genre ce matin. Mais le client MySQL que j'utilise (CocoaMySQL sur MacOSX) permet de forcer le charset de destination. Et en forçant l'utf-8 lors de l'import du script SQL je n'ai plus de souci.

Tu utilises quel soft pour ré-injecter tes données ? Un PhpMyadmin tout bête, une interface fournie par un plugin DC ou un client MySQL logiciel ?

FloBaoti
WRInaute passionné
WRInaute passionné
 
Messages: 684
Inscription: Dim Avr 30, 2006 18:42

Message le Lun Juil 14, 2008 17:50

Justement je ne veux pas faire d'export-import. Je veux insérer des données dans une table depuis une autre table. En une seule requête comme l'exemple que j'ai donné.


Koidirou
WRInaute discret
WRInaute discret
 
Messages: 52
Inscription: Jeu Mai 03, 2007 18:00

Message le Lun Juil 14, 2008 22:25

De mémoire, il y a un plugin Dotclear 1 (installé par défaut je crois) pour passer ton blog en UTF-8. Ça te permettra ensuite de passer à Dotclear 2 sans soucis.

Sinon, regarde par là : http://doc.dotclear.net/2.0/admin/1-to-2


Formation recommandée sur ce thème :

Formation Référencement naturel Google : apprenez une méthode efficace pour optimiser à fond le référencement naturel dans Google de façon durable... Formation animée par Olivier Duffez et Fabien Facériès, experts en référencement naturel.

Tous les détails sur le site Ranking Metrics : programme, prix, dates et lieux, inscription en ligne.

Lectures recommandées sur ce thème :



Qui est en ligne

Utilisateurs parcourant ce forum: Aucun utilisateur enregistré et 0 invités