Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en 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 07/09/2007, 17h02   #1
Invité de passage
 
Inscription : septembre 2007
Messages : 4
Détails du profil
Informations personnelles :
Localisation : France

Informations forums :
Inscription : septembre 2007
Messages : 4
Points : 3
Points : 3
Par défaut Variables caractères dans le Log Binaire.

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.
Cyril_A est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/09/2007, 12h03   #2
Invité de passage
 
Inscription : septembre 2007
Messages : 4
Détails du profil
Informations personnelles :
Localisation : France

Informations forums :
Inscription : septembre 2007
Messages : 4
Points : 3
Points : 3
Par défaut Trouvé

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.
Cyril_A 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 09h44.


 
 
 
 
Partenaires

Hébergement Web