SPIP-Contrib

SPIP-Contrib

عربي | Deutsch | English | Español | français | italiano

274 Plugins, 192 contribs sur SPIP-Zone, 238 visiteurs en ce moment

Accueil > 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

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

17 mars 2004 (Date de rédaction antérieure : 17 mars 2004). – par Déesse A.

Ceci est une archive périmée mais qui reste intéressante, parfois autant pour l’article que les commentaires associés.

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.

Retour en haut de la page

Répondre à cet article

Qui êtes-vous ?

Pour afficher votre trombine avec votre message, enregistrez-la d'abord sur gravatar.com (gratuit et indolore) et n'oubliez pas d'indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici Les choses à faire avant de poser une question (Prolégomènes aux rapports de bugs. )
Ajouter un document

Retour en haut de la page

Ça discute par ici

  • MediaBox

    10 mai 2010 – 192 commentaires

    Aperçu La MediaBox est une Boîte multimédia polyvalente et personnalisable. Le plugin est basé sur la librairie moderne ColorBox, qui a été enrichie et adaptée pour SPIP. Par défaut, mediabox propose 5 habillages. Il est assez facile d’en créer de (...)

  • Analyclick - un compteur de téléchargements

    26 février 2011 – 58 commentaires

    Ce plugin permet de compter les téléchargements de documents sur son site. Il introduit une balise #URL_DOC_COMPTEUR qui va compter chaque clic fait sur ce lien. Il affiche une page de statistique. Installation Le plugin s’installe comme tout (...)

  • Plugin SPIPAL

    10 janvier 2011 – 84 commentaires

    Pour intégrer un système de paiement immédiat via PayPal à certains de vos articles . Ce plugin est une mise à niveau pour la version SPIP 2.1.8 du Plugin GoPayPal qui était resté en SPIP 1.9.2 depuis 3 ans. Il change de nom pour ne pas faire trop (...)

  • SPIP 3.0

    19 mai – 13 commentaires

    Nous avons le plaisir de vous annoncer la sortie de SPIP 3.0 ! Cette nouvelle version vous permet toujours de publier du contenu pour internet et de créer des sites avec une grande facilité. De nombreuses évolutions facilitent son utilisation (...)

  • Les Boîtes Privées

    3 janvier 2008 – 24 commentaires

    Les « Boîtes Privées » sont des cadres qui peuvent apparaître selon vos souhaits ici ou là dans la partie privée de votre site et vous donner des renseignements parfois fort utiles : Les articles au format SPIP, Les auteurs en stat, Les URLs propres, (...)