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

Requêtes MySQL Discussion :

Comportement étrange avec les index et "order by"


Sujet :

Requêtes MySQL

  1. #1
    Membre éclairé
    Avatar de Dia_FR
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2006
    Messages : 512
    Points : 708
    Points
    708
    Par défaut Comportement étrange avec les index et "order by"
    bonjour,

    j'ai rencontré un comportement étrange de ma BD et après quelques tests j'ai trouvé la solution, sauf que je n'ai compris ni l'origine du problème ni le pourquoi de la solution donc si quelqu'un peut éclairer ma lanterne...

    en MySQL 5, moteur InnoDB, voilà le script correspondant à la table en question, en ne gardant que le code pertinent :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    CREATE TABLE `fxc_pages` (
      `page_id` int(11) unsigned NOT NULL auto_increment,
      `page_code` varchar(255) collate latin1_general_ci NOT NULL,
      `site_id` int(11) unsigned NOT NULL,
      `template_id` int(11) unsigned NOT NULL,
      `parent_id` int(11) unsigned default NULL,
      `page_order` int(11) unsigned NOT NULL default '0',
      PRIMARY KEY  (`page_id`),
      UNIQUE KEY `page_code` (`page_code`,`site_id`),
      UNIQUE KEY `page_order` (`site_id`,`parent_id`,`page_order`),
      KEY `parent_id` (`parent_id`),
      KEY `template_id` (`template_id`),
      KEY `site_id` (`site_id`),
      CONSTRAINT `fxc_pages_parent_id` FOREIGN KEY (`parent_id`) REFERENCES `fxc_pages` (`page_id`) ON DELETE CASCADE,
      CONSTRAINT `fxc_pages_site_id` FOREIGN KEY (`site_id`) REFERENCES `fxc_sites` (`site_id`) ON DELETE CASCADE,
      CONSTRAINT `fxc_pages_template_id` FOREIGN KEY (`template_id`) REFERENCES `fxc_templates` (`template_id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=latin1 COLLATE=latin1_general_ci;
    donc en gros, une PK, 3 FK avec chacune un index et 2 index unique dont un portant sur 3 colonnes

    avec cette structure, une requête comme celle là, le order by n'était pas pris en compte
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    update fxc_pages set page_order = page_order - 1 where site_id = x and parent_id = y and page_order <= z and page_order > t order by page_order asc
    pour régler le problème, il a suffit de virer la clé sur site_id :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      KEY `site_id` (`site_id`),
    je ne suis pas un pro MySQL et je connais les détails de sa gestion des index et des clés donc si quelqu'un sait...
    merci d'avance

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 801
    Points : 34 062
    Points
    34 062
    Billets dans le blog
    14
    Par défaut
    Euh... ça sert à quoi de faire un ORDER BY sur une requête UPDATE ?

  3. #3
    Membre éclairé
    Avatar de Dia_FR
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2006
    Messages : 512
    Points : 708
    Points
    708
    Par défaut
    à l'exécuter sur les enregistrements dans un certain ordre
    dans le cas que j'ai présenté j'ai une clé d'unicité sur order, site et parent
    je dois changer la valeur de order, pour un site et un parent donnés
    pour le faire en une seule requete sans violer l'unicité, je les ordonne par order ascendant si je dois faire order--, ou par order descendant si je dois faire order++
    fin bon c de l'algo de base quoi

  4. #4
    Expert confirmé

    Homme Profil pro
    SDE
    Inscrit en
    Août 2007
    Messages
    2 013
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : SDE

    Informations forums :
    Inscription : Août 2007
    Messages : 2 013
    Points : 4 327
    Points
    4 327
    Par défaut
    La clause UPDATE effectue un traitement ensembliste, c'est-à-dire que si tu fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SET un_champ = un_champ + 1
    Tous les champs sont modifié en même temps, il n'y a donc pas de viol au niveau de l'intégrité.

    Bien évidement dans l'exécution de la requête il dois y avoir un traitement séquentiel mais, mais le contrôle s'effectue après l'update (comme si on ouvrais une transaction avant, et on faisait un COMIT après).
    D'ailleurs le DML est une transaction un court moment.

  5. #5
    Membre éclairé
    Avatar de Dia_FR
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2006
    Messages : 512
    Points : 708
    Points
    708
    Par défaut
    intéressant à savoir, je ne crois pas que j'avais essayé, partant du principe que le contrôle d'intégrité se faisait à chaque modification d'un enregistrement, j'essaie ça dès lundi !

  6. #6
    Membre éclairé
    Avatar de Dia_FR
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2006
    Messages
    512
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Avril 2006
    Messages : 512
    Points : 708
    Points
    708
    Par défaut
    nan ba en virant le "order by" sur l'update, ça foire bien en posant une "integrity constraint violation"

    donc j'en reviens à ma question de base si quelqu'un sait...

Discussions similaires

  1. Comportement étrange avec "order by"
    Par Warluck dans le forum SQL
    Réponses: 2
    Dernier message: 04/11/2010, 21h06
  2. [TRANSAQ SQL] INSERT comportement bizarre avec les REAL
    Par argyronet dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/12/2005, 11h47
  3. Résultat étrange avec les lumières.
    Par MaxPayne dans le forum OpenGL
    Réponses: 4
    Dernier message: 12/04/2005, 18h04
  4. Paradox:Probleme avec les index
    Par byte dans le forum Bases de données
    Réponses: 2
    Dernier message: 06/01/2005, 16h08

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