SPIP - Contrib

[ar] [en] [es] [fr] [it]



Accueil du site > Documentation > Tutoriaux pour le code de SPIP > Archives tutoriaux code SPIP > La genèse du nouveau compilateur

Compilateur de squelette à requêtes multi-valuées

mercredi 17 mars 2004, par Déesse A.. Dernier ajout lundi 1er octobre 2007



Cette version 4 du compilateur dont les versions précedentes sont décrites ici est une solution au bug 168 posté sur spip_commit, dont je reprends le texte :

je cherche à afficher un article qui possède deux mots clé. j’ai bien pensé à id_mot==^(16|2)$ mais ca marche pas.

Réponse

En théorie ça devrait être {id_mot=16}{id_mot=2} (les critères forment un "ET" logique entre eux) ; mais en pratique ça ne marchera pas, car c’est mal implémenté (bug connu et jamais résolu).

Le présent compilateur repère qu’un meme champ est comparé (avec =) plusieurs fois à une constante (comme ci-dessus). La sémantique implicite de SPIP est une conjonction des paramètres (donc un AND en SQL) qui est ici clairement inopérante puisqu’un champ ne peut avoir simultanémenet deux valeurs. Plutot que de déclencher une erreur (c’était mon intention initiale) le présent compilateur synthétise une seule clause, de la forme id_mot IN (16,2). Comme il faut en outre s’assurer que ces deux valeurs ont été rencontrées, la requête produite comporte également le calcul du COUNT(id_mot) qui doit etre égal à 2. Pour cette dernière contrainte, j’ai dû utiliser MySQL 4.1 pour bénéficier des requêtes imbriquées ; il y a peut-etre plus simple.

Les remarques sont les bienvenues.

P.-S.

PS : je ne joins que le fichier inc-reqsql-squel, les autres étant toujours ceux de la version précédente.

Documents joints


Répondre à cet article



Suivre la vie du site RSS 2.0 | Plan du site | Espace privé | Charte et vie SPIP-Contrib | SPIP | L'autre.net