SPIP-Contrib

SPIP-Contrib

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

288 Plugins, 197 contribs sur SPIP-Zone, 222 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.

0 vote

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.

Dernière modification de cette page le 1er octobre 2007

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

  • GIS 4

    11 août 2012 – 1410 commentaires

    Présentation et nouveautés La version 4 de GIS abandonne la libraire Mapstraction au profit de Leaflet. Cette librairie permet de s’affranchir des librairies propriétaires tout en gardant les mêmes fonctionnalités, elle propose même de nouvelles (...)

  • Plugin Domlang : Domaines par secteur de langue

    4 septembre – commentaires

    Domlang est un plugin qui permet d’associer un nom de domaine ou un sous-domaine à un secteur de langue. Ce plugin convient pour un site qui utilise des secteurs de langues. En configuration, pour chaque secteur, vous pourrez définir une URL (...)

  • Menu de langues sous forme de liens

    30 novembre 2009 – 121 commentaires

    Par défaut, le menu de langue de SPIP s’affiche : Sous la forme d’une liste déroulante ; En affichant toutes les langues du site, qu’elles soient utilisées ou non (c’est à même si elles ne sont pas affectées à au moins un article ou une rubrique) ; Sans (...)

  • Agenda 2.0

    3 novembre 2008 – 1098 commentaires

    Voici la version pour SPIP 2.0 du Plugin Agenda pour SPIP 1.9.2, avec une interface remaniée pour encore plus de plaisir. Pour une documentation concernant l’utilisation d’Agenda 3 pour SPIP 3, veuillez pour l’instant vous référer à SPIP 3, Agenda (...)

  • Mailsubscribers

    16 janvier 2013 – 332 commentaires

    Ce plugin permet de gérer les inscriptions (ou abonnements) à la diffusion de contenu par email. Mailsubscribers permet de gérer les inscriptions par Opt-in simple ou double et la désinscription par URL. Ce plugin gère également plusieurs listes de (...)