IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

SQL Procédural MySQL Discussion :

Variables caractères dans le Log Binaire.


Sujet :

SQL Procédural MySQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 4
    Points : 5
    Points
    5
    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.

  2. #2
    Futur Membre du Club
    Profil pro
    Inscrit en
    Septembre 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2007
    Messages : 4
    Points : 5
    Points
    5
    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.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 9
    Dernier message: 19/03/2013, 16h58
  2. Réponses: 10
    Dernier message: 09/02/2008, 12h40
  3. Selectionné caractère dans variable
    Par bov13 dans le forum VBScript
    Réponses: 5
    Dernier message: 23/01/2007, 11h48
  4. Réponses: 5
    Dernier message: 08/03/2006, 23h20
  5. Problème avec certains caractéres dans variable
    Par Off$ide dans le forum Langage
    Réponses: 14
    Dernier message: 13/12/2005, 11h46

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo