|
Publicité ' | |||||||||||||||||||||||
|
|
#1 |
|
Invité de passage
![]() Inscription : septembre 2007 Messages : 4 ![]() |
Bonjour,
Dans mes procédures stoquées les variables (uniquement CHAR et VARCHAR) déclarées sont utilisées pour des update ou insert sans aucune erreur. Par contre le log binaire n'inscrit pas ou mal la valeur des variables de type caractère, je me suis apperçut de ce Pb. en restaurant un log binaire. Test réalisé : -- version: 5.0.18-nt-log mysql> CREATE TABLE T (Id VARCHAR(10) NOT NULL DEFAULT '',CPT INTEGER UNSIGNED NOT NULL DEFAULT 0,PRIMARY KEY(Id)) ENGINE = InnoDB; Query OK, 0 rows affected (0.14 sec) mysql> SET @a='TEST'; Query OK, 0 rows affected (0.02 sec) mysql> INSERT INTO T VALUES (@a,1); Query OK, 1 row affected (0.08 sec) mysql> UPDATE T SET CPT = CPT+1 WHERE Id=@a; Query OK, 1 row affected (0.06 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql> SELECT * FROM T; +------+-----+ | Id | CPT | +------+-----+ | TEST | 2 | +------+-----+ 1 row in set (0.00 sec) Jusque là aucun soucis. Après avoir supprimé la table T, je regénère mon Log Binaire et voici le résultat : ERROR 1231 (42000) at line 7: Variable 'sql_mode' can't be set Résultat : Je ne peux pas restaurer à partir des log binaires les données issues de mes variables caractères dans mes procédures stockées la réplication idem se met en erreur. Merci d'avance, Cyril. |
|
|
00
|
|
|
#2 |
|
Invité de passage
![]() Inscription : septembre 2007 Messages : 4 ![]() |
Le Pb. venait de ma version : MySQL 5.0.18.
En effet : As of MySQL 5.0.19, the character_set_filesystem system variable controls interpretation of filenames that are given as literal strings. (Valable aussi pour les variables de type caractère inscritent dans le log-binaire). Mon interprétation : Ces valeurs caractères sont inscritent dans le log-binaire en mode binaire (Ex.: "SET @a='TEST';" dans le log binaire = "SET @`a`:=_latin1 0x54455354 COLLATE `latin1_swedish_ci`/*!*/;"). A partir de la 5.0.19 une nouvelle variable system "character_set_filesystem=binary" permet de restaurer à partir du log-binaire et la réplication du même coup fonctionne très bien pour les variables de type caractère. Cyril. |
|
|
00
|
Copyright © 2000-2012 - www.developpez.com