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.
Partager