Subversion Repositories eFlore/Applications.bibliobota

Rev

Rev 2 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2 Rev 30
Line 1... Line 1...
1
<?php
1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */ 
3
// +------------------------------------------------------------------------------------------------------+
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
7
// +------------------------------------------------------------------------------------------------------+
8
// | This library is free software; you can redistribute it and/or                                        |
8
// | This library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
9
// | modify it under the terms of the GNU Lesser General Public                                           |
10
// | License as published by the Free Software Foundation; either                                         |
10
// | License as published by the Free Software Foundation; either                                         |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
11
// | version 2.1 of the License, or (at your option) any later version.                                   |
12
// |                                                                                                      |
12
// |                                                                                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
13
// | This library is distributed in the hope that it will be useful,                                      |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
14
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
15
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
16
// | Lesser General Public License for more details.                                                      |
16
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
18
// | You should have received a copy of the GNU Lesser General Public                                     |
19
// | License along with this library; if not, write to the Free Software                                  |
19
// | License along with this library; if not, write to the Free Software                                  |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
20
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
21
// +------------------------------------------------------------------------------------------------------+
21
// +------------------------------------------------------------------------------------------------------+
22
// CVS : $Id: bbc_requete_media.fonct.php,v 1.1 2005-11-23 10:22:25 jp_milcent Exp $
22
// CVS : $Id: bbc_requete_media.fonct.php,v 1.3 2004/09/15 10:32:30 jpm Exp $
23
/**
23
/**
24
* Fonctions de création de la requête sur un média.
24
* Fonctions de création de la requête sur un média.
25
*
25
*
26
* Contient une fonction créant la requête d'intérogation de la base de données.
26
* Contient une fonction créant la requête d'intérogation de la base de données.
27
* Valable pour le paramètre "media".
27
* Valable pour le paramètre "media".
28
*
28
*
29
*@package BiblioBota-Consultation
29
*@package BiblioBota-Consultation
30
*@subpackage Fonctions
30
*@subpackage Fonctions
31
//Auteur original :
31
//Auteur original :
32
*@author        Jean-Charles GRANGER <tela@vecteur.org>
32
*@author        Jean-Charles GRANGER <tela@vecteur.org>
33
//Autres auteurs :
33
//Autres auteurs :
34
*@author        Jean-Pascal MILCENT <jpm@clapas.org>
34
*@author        Jean-Pascal MILCENT <jpm@clapas.org>
35
*@copyright     Tela-Botanica 2000-2004
35
*@copyright     Tela-Botanica 2000-2004
36
*@version       $Revision: 1.1 $ $Date: 2005-11-23 10:22:25 $
36
*@version       $Revision: 1.3 $ $Date: 2004/09/15 10:32:30 $
37
// +------------------------------------------------------------------------------------------------------+
37
// +------------------------------------------------------------------------------------------------------+
38
*/
38
*/
39
 
39
 
40
// +------------------------------------------------------------------------------------------------------+
40
// +------------------------------------------------------------------------------------------------------+
41
// |                                            ENTETE du PROGRAMME                                       |
41
// |                                            ENTETE du PROGRAMME                                       |
42
// +------------------------------------------------------------------------------------------------------+
42
// +------------------------------------------------------------------------------------------------------+
43
 
-
 
44
 
43
 
45
// +------------------------------------------------------------------------------------------------------+
-
 
46
// |                                           LISTE de FONCTIONS                                         |
-
 
47
// +------------------------------------------------------------------------------------------------------+
-
 
Line -... Line 44...
-
 
44
 
-
 
45
// +------------------------------------------------------------------------------------------------------+
-
 
46
// |                                           LISTE de FONCTIONS                                         |
-
 
47
// +------------------------------------------------------------------------------------------------------+
48
 
48
 
49
/** Fonction mkquery() - Créé une requête intérogeant la base de donnée.
49
/** Fonction mkquery() - Créé une requête intérogeant la base de donnée.
50
*
50
*
51
* Fonction créant la requête d'intérogation de la base de données pour le
51
* Fonction créant la requête d'intérogation de la base de données pour le
52
* paramêtre "media".
52
* paramêtre "media".
53
*
53
*
54
* @return  string la requête permettant de récupérer les média.
54
* @return  string la requête permettant de récupérer les média.
55
*/
55
*/
56
function mkquery()
56
function mkquery()
57
{
57
{
58
    global $tbl;
58
    global $tbl;
Line 65... Line 65...
65
    // si limit_domain vaut 1, alors on réduit les recherches au seul domaine botanique
65
    // si limit_domain vaut 1, alors on réduit les recherches au seul domaine botanique
Line 66... Line 66...
66
    
66
    
67
    if ($var_biblio['limit_domain'] == 1) {
67
    if ($var_biblio['limit_domain'] == 1) {
68
        $add_from_dom = ', '.$tbl['domaine'].', '.$tbl['domaine_lk'];
68
        $add_from_dom = ', '.$tbl['domaine'].', '.$tbl['domaine_lk'];
69
        // lien domaines -- table de jointure domaines
69
        // lien domaines -- table de jointure domaines
70
        $add_limit_dom = ' AND ('.$tbl['domaine'].'.B_D_ID = '.$tbl['domaine_lk'].'.B_DL_IDDOM)';
70
        $add_limit_dom = ' AND ('.$tbl['domaine'].'.B_D_ID = '.$tbl['domaine_lk'].'.B_DL_IDDOM)';
71
        // lien articles -- table de jointure domaines
71
        // lien articles -- table de jointure domaines
72
        $add_limit_dom .= ' AND ('.$tbl['item'].'.B_I_IDITEM = '.$tbl['domaine_lk'].'.B_DL_IDITEM)';
72
        $add_limit_dom .= ' AND ('.$tbl['item'].'.B_I_IDITEM = '.$tbl['domaine_lk'].'.B_DL_IDITEM)';
73
        $add_limit_dom .= ' AND '.$tbl['domaine'].'.B_D_ID = 1';
73
        $add_limit_dom .= ' AND '.$tbl['domaine'].'.B_D_ID = 1';
74
    } else {
74
    } else {
75
        $add_from_dom = ', '.$tbl['domaine'].', '.$tbl['domaine_lk'];
75
        $add_from_dom = ', '.$tbl['domaine'].', '.$tbl['domaine_lk'];
76
        // lien domaines -- table de jointure domaines
76
        // lien domaines -- table de jointure domaines
77
        $add_limit_dom = ' AND ('.$tbl['domaine'].'.B_D_ID = '.$tbl['domaine_lk'].'.B_DL_IDDOM)';
77
        $add_limit_dom = ' AND ('.$tbl['domaine'].'.B_D_ID = '.$tbl['domaine_lk'].'.B_DL_IDDOM)';
78
        // lien articles -- table de jointure domaines
78
        // lien articles -- table de jointure domaines
79
        $add_limit_dom .= ' AND ('.$tbl['item'].'.B_I_IDITEM = '.$tbl['domaine_lk'].'.B_DL_IDITEM)';
79
        $add_limit_dom .= ' AND ('.$tbl['item'].'.B_I_IDITEM = '.$tbl['domaine_lk'].'.B_DL_IDITEM)';
Line 80... Line 80...
80
    }
80
    }
Line 103... Line 103...
103
        $special_join .= ' AND ('.$tbl['fascicule'].'.B_F_NUMERO = '.$tbl['article'].'.B_A_CRAIFASC)';
103
        $special_join .= ' AND ('.$tbl['fascicule'].'.B_F_NUMERO = '.$tbl['article'].'.B_A_CRAIFASC)';
104
        // jointure item - article
104
        // jointure item - article
105
        $special_join .= ' AND ('.$tbl['item'].'.B_I_IDITEM = '.$tbl['article'].'.B_A_IDART)';
105
        $special_join .= ' AND ('.$tbl['item'].'.B_I_IDITEM = '.$tbl['article'].'.B_A_IDART)';
Line 106... Line 106...
106
        
106
        
107
        // réducteur de catégorie (collections) categ
107
        // réducteur de catégorie (collections) categ
108
        if ($TabFinder['categ'] != '') {
108
        if ($TabFinder['categ'] != '') {
109
            $add_to_query = ' AND ('.$tbl['article'].'.B_A_CRAICOLL like "'.$TabFinder['categ'].'%")';
109
            $add_to_query = ' AND ('.$tbl['article'].'.B_A_CRAICOLL like "'.$TabFinder['categ'].'%")';
110
        } else {
110
        } else {
111
            $add_to_query = '';
111
            $add_to_query = '';
112
        }
112
        }
113
    } else {
113
    } else {
114
        // On demande ici les livres et médias
114
        // On demande ici les livres et médias
115
        $add_select = $tbl['media'].'.*, '.$tbl['monnaie'].'.*, ';
115
        $add_select = $tbl['media'].'.*, '.$tbl['monnaie'].'.*, ';
116
        // Ajout du FROM
116
        // Ajout du FROM
117
        $add_from = $tbl['media'].' LEFT JOIN '.$tbl['str'].' ON B_M_LKSTR = B_S_IDSTR, '.$tbl['monnaie'].', ';
117
        $add_from = $tbl['media'].' LEFT JOIN '.$tbl['str'].' ON B_M_LKSTR = B_S_IDSTR, '.$tbl['monnaie'].', ';
118
        // lien media -- article
118
        // lien media -- article
119
        $special_join = ' AND ('.$tbl['media'].'.B_M_IDMEDIA = '.$tbl['item'].'.B_I_IDITEM)';
119
        $special_join = ' AND ('.$tbl['media'].'.B_M_IDMEDIA = '.$tbl['item'].'.B_I_IDITEM)';
120
        // lien media -- monnaie
120
        // lien media -- monnaie
121
        $special_join .= ' AND ('.$tbl['media'].'.B_M_LKMONNAIE = '.$tbl['monnaie'].'.GEN_MON_IDMONNAIE)';
121
        $special_join .= ' AND ('.$tbl['media'].'.B_M_LKMONNAIE = '.$tbl['monnaie'].'.GEN_MON_IDMONNAIE)';
122
        //pas de réducteur de catégorie pour les livres
122
        //pas de réducteur de catégorie pour les livres
123
        $add_to_query = '';
123
        $add_to_query = '';
Line 124... Line 124...
124
    }
124
    }
125
    
125
    
126
    // Compte Total : comptage du nombre de données de la table
126
    // Compte Total : comptage du nombre de données de la table
127
    // d'abord, créer les critères de sélection physiques et logiques.
127
    // d'abord, créer les critères de sélection physiques et logiques.
128
    if (($TabFinder['categ_3'] == '') || (BB_ARGUMENT_REGROUPEMENT == 'article')) {
128
    if (($TabFinder['categ_3'] == '') || (BB_ARGUMENT_REGROUPEMENT == 'article')) {
129
        if ((!empty($query_dom['log']))) {
129
        if ((!empty($query_dom['log']))) {
130
            $create_log = $query_dom['log'];
130
            $create_log = $query_dom['log'];
131
        } else {
131
        } else {
132
            $create_log = '';
132
            $create_log = '';
133
        }
133
        }
134
    } else {
134
    } else {
Line 135... Line 135...
135
        $create_log = 'B_I_TYPLOG = '.$TabFinder['categ_3'];
135
        $create_log = 'B_I_TYPLOG = '.$TabFinder['categ_3'];
136
    }
136
    }
137
    
137
    
138
    if ($TabFinder['categ_2'] == '') {
138
    if ($TabFinder['categ_2'] == '') {
139
        if ((!empty($query_dom['phy']))) {
139
        if ((!empty($query_dom['phy']))) {
140
            $create_phy = $query_dom['phy'];
140
            $create_phy = $query_dom['phy'];
141
        } else {
141
        } else {
142
            $create_phy = '';
142
            $create_phy = '';
143
        }
143
        }
Line 144... Line 144...
144
    } else {
144
    } else {
145
        $create_phy = 'B_I_TYPPHY = '.$TabFinder['categ_2'];
145
        $create_phy = 'B_I_TYPPHY = '.$TabFinder['categ_2'];
146
    }
146
    }
Line 237... Line 237...
237
    }
237
    }
Line 238... Line 238...
238
    
238
    
Line 239... Line 239...
239
    /* ajout, si nécessaire, de la contrainte categ */
239
    /* ajout, si nécessaire, de la contrainte categ */
240
    
240
    
241
    if (($TabFinder['categ'] != '') && (BB_ARGUMENT_REGROUPEMENT == 'media')) {
241
    if (($TabFinder['categ'] != '') && (BB_ARGUMENT_REGROUPEMENT == 'media')) {
242
        if ($TabFinder['categ'] == 'VIDE') {
242
        if ($TabFinder['categ'] == 'VIDE') {
243
            $normal_query .= ' AND (B_M_EDITEUR is null OR B_M_EDITEUR = "")';
243
            $normal_query .= ' AND (B_M_EDITEUR is null OR B_M_EDITEUR = "")';
244
        } else {
244
        } else {
245
            $normal_query .= ' AND (B_M_EDITEUR like "%'.$TabFinder['categ'].'%")';
245
            $normal_query .= ' AND (B_M_EDITEUR like "%'.$TabFinder['categ'].'%")';
Line 246... Line 246...
246
        }
246
        }
247
    }
247
    }
Line 261... Line 261...
261
        
261
        
Line 262... Line 262...
262
        $normal_query .= ' AND (';
262
        $normal_query .= ' AND (';
263
        
263
        
264
        for ($tmp=0;$tmp<count($tmp_auteur);$tmp++) {
264
        for ($tmp=0;$tmp<count($tmp_auteur);$tmp++) {
265
            $normal_query .= $tbl['item'].'.B_I_AUTEURS like "%'.$tmp_auteur[$tmp].'%"';
265
            $normal_query .= $tbl['item'].'.B_I_AUTEURS like "%'.$tmp_auteur[$tmp].'%"';
266
            if ( $tmp < (count($tmp_auteur) - 1) ) {
266
            if ( $tmp < (count($tmp_auteur) - 1) ) {
267
                $normal_query .= ' AND ';
267
                $normal_query .= ' AND ';
268
            }
268
            }
269
        }
269
        }
Line 270... Line 270...
270
        $normal_query .= ')';
270
        $normal_query .= ')';
271
    }
271
    }
272
    
272
    
Line 273... Line 273...
273
    // Si TabFinder['geo'] est non vide :
273
    // Si TabFinder['geo'] est non vide :
274
    // 1- si TabFinder['chaine'] est vide on n'ajoute pas de AND
274
    // 1- si TabFinder['chaine'] est vide on n'ajoute pas de AND
275
    // 2- s'il n'est pas vide on ajoute AND
275
    // 2- s'il n'est pas vide on ajoute AND
276
    
276
    
277
    if ($TabFinder['geo'] != '') {
277
    if ($TabFinder['geo'] != '') {
278
        if ($TabFinder['geo'] == '1' || $TabFinder['geo'] == '2' || $TabFinder['geo'] == '3' || $TabFinder['geo'] == '4' 
278
        if ($TabFinder['geo'] == '1' || $TabFinder['geo'] == '2' || $TabFinder['geo'] == '3' || $TabFinder['geo'] == '4' 
Line 294... Line 294...
294
            
294
            
295
            while ($row = mysql_fetch_object($comp_do)) {
295
            while ($row = mysql_fetch_object($comp_do)) {
Line 296... Line 296...
296
                $tmp_stock = $row->GFD_ID;
296
                $tmp_stock = $row->GFD_ID;
297
                
297
                
298
                if ($tmp_stock != '') {
298
                if ($tmp_stock != '') {
299
                    if ($tmp_stock == '1' || $tmp_stock == '2' || $tmp_stock == '3' || $tmp_stock == '4' ||
299
                    if ($tmp_stock == '1' || $tmp_stock == '2' || $tmp_stock == '3' || $tmp_stock == '4' ||
300
                        $tmp_stock == '5' || $tmp_stock == '6' || $tmp_stock == '7' || $tmp_stock == '8' || $tmp_stock == '9' ) {
300
                        $tmp_stock == '5' || $tmp_stock == '6' || $tmp_stock == '7' || $tmp_stock == '8' || $tmp_stock == '9' ) {
301
                        $tmp_stock = '0'.$tmp_stock;
301
                        $tmp_stock = '0'.$tmp_stock;
Line 302... Line 302...
302
                        $tmp_stock = ereg_replace('00', '0', $tmp_stock);
302
                        $tmp_stock = ereg_replace('00', '0', $tmp_stock);
303
                    }
303
                    }
304
                    
304
                    
305
                    if ($i == 1) {
305
                    if ($i == 1) {
306
                        $normal_query .= ' OR (';
306
                        $normal_query .= ' OR (';
307
                    }
307
                    }
308
                    $normal_query .= $tbl['item'].'.B_I_GEO like "%'.$tmp_stock.'%"';
308
                    $normal_query .= $tbl['item'].'.B_I_GEO like "%'.$tmp_stock.'%"';
309
                    if ($i < $comp_num) {
309
                    if ($i < $comp_num) {
310
                        $normal_query .= ' OR ';
310
                        $normal_query .= ' OR ';
311
                    }
311
                    }
312
                    if ($i == $comp_num) {
312
                    if ($i == $comp_num) {
313
                        $normal_query .= ') ';
313
                        $normal_query .= ') ';
314
                    }
314
                    }
315
                    $i++;
315
                    $i++;
Line 323... Line 323...
323
    // traitement du réducteur SINCE (fonction de la date)
323
    // traitement du réducteur SINCE (fonction de la date)
Line 324... Line 324...
324
    
324
    
325
    if ($TabFinder['since'] != '') {
325
    if ($TabFinder['since'] != '') {
Line 326... Line 326...
326
        $since_var = explode('/', $TabFinder['since']);
326
        $since_var = explode('/', $TabFinder['since']);
327
        
327
        
328
        if (empty($since_var[0])) {
328
        if (empty($since_var[0])) {
329
            $since_var[0] = '';
329
            $since_var[0] = '';
330
        }
330
        }
331
        if (empty($since_var[1])) {
331
        if (empty($since_var[1])) {
332
            $since_var[1] = '';
332
            $since_var[1] = '';
333
        }
333
        }
334
        if (empty($since_var[2])) {
334
        if (empty($since_var[2])) {
Line 335... Line 335...
335
            $since_var[2] = '';
335
            $since_var[2] = '';
Line 336... Line 336...
336
        }
336
        }
337
        
337
        
Line 338... Line 338...
338
        $timestamp = mktime (NULL,NULL,NULL,$since_var[1],$since_var[0],$since_var[2]);
338
        $timestamp = mktime (NULL,NULL,NULL,$since_var[1],$since_var[0],$since_var[2]);
339
        
339
        
Line 340... Line 340...
340
        $normal_query .= ' AND B_I_MAJFICHE > '.$timestamp;
340
        $normal_query .= ' AND B_I_MAJFICHE > '.$timestamp;
341
    }
341
    }
342
    
342
    
343
    // Création de l'ordre de tri
343
    // Création de l'ordre de tri
Line 344... Line 344...
344
    $order_query = " ORDER BY ".$TabFinder['sort'];
344
    $order_query = " ORDER BY ".$TabFinder['sort'];
Line 345... Line 345...
345
    
345
    
-
 
346
    // Affectation de la requête à la variable qui va l'envoyer au moteur
Line 346... Line 347...
346
    // Affectation de la requête à la variable qui va l'envoyer au moteur
347
    if (empty($plugin_store['query_add_query'])) {
347
    if (empty($plugin_store['query_add_query'])) {
348
        $plugin_store['query_add_query'] = '';
348
        $plugin_store['query_add_query'] = '';
349
    }
349
    }
350
    
350
    
351
    $unreq = $normal_query.' '.$add_to_query.' '.$plugin_store['query_add_query'].' '.$order_query;
351
    $unreq = $normal_query.' '.$add_to_query.' '.$plugin_store['query_add_query'].' '.$order_query;
352
    
352
    
-
 
353
    //echo "$unreq";
-
 
354
    
-
 
355
    return $unreq;
353
    // Débogage de la requête
356
}
354
    //trigger_error($unreq, E_USER_WARNING);
357
 
355
    
358
/* +--Fin du code ----------------------------------------------------------------------------------------+
356
    return $unreq;
359
*
357
}
360
* $Log: not supported by cvs2svn $
358
 
361
* Revision 1.4  2005/05/17 10:10:08  jpm
359
/* +--Fin du code ----------------------------------------------------------------------------------------+
362
* Correction des bogues avant mise en ligne du site v4.
360
*
363
*
361
* $Log: bbc_requete_media.fonct.php,v $
-
 
362
* Revision 1.3  2004/09/15 10:32:30  jpm
364
* Revision 1.3  2004/09/15 10:32:30  jpm
363
* Suppression d'une ligne après la balise de fermeture php.
365
* Suppression d'une ligne après la balise de fermeture php.
-
 
366
*
364
*
367
* Revision 1.2  2004/09/14 10:18:17  jpm
365
* Revision 1.2  2004/09/14 10:18:17  jpm
368
* Mise en forme et amélioration du code.
366
* Mise en forme et amélioration du code.
369
* Passage au XHTML strict.
367
* Passage au XHTML strict.