Subversion Repositories eFlore/Applications.del

Rev

Rev 1889 | Rev 1933 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1889 Rev 1922
Line 43... Line 43...
43
		'where' => array(),
43
		'where' => array(),
44
		'groupby' => array(),
44
		'groupby' => array(),
45
		'orderby' => array());
45
		'orderby' => array());
Line 46... Line 46...
46
 
46
 
47
	private $champsPrenom = array('du.prenom', 'prenom_utilisateur');
47
	private $champsPrenom = array('du.prenom', 'prenom_utilisateur');
48
	private $champsNom = array('du.nom',  'nom_utilisateur');
-
 
-
 
48
	private $champsNom = array('du.nom', 'nom_utilisateur');
Line 49... Line 49...
49
 
49
	private $champsSousRequeteObs = array('masque.genre', 'masque.famille', 'masque.ns', 'masque.commune', 'masque.milieu');
50
 
50
 
51
	public function __construct(Conteneur $conteneur) {
51
	public function __construct(Conteneur $conteneur) {
52
		$this->conteneur = $conteneur;
52
		$this->conteneur = $conteneur;
Line 81... Line 81...
81
		return $this->requete;
81
		return $this->requete;
82
	}
82
	}
Line 83... Line 83...
83
 
83
 
84
	private function addJoin($join) {
84
	private function addJoin($join) {
85
		if (!isset($this->requete['join'][$join])) {
85
		if (!isset($this->requete['join'][$join])) {
86
			$this->requete['join'][] = $join;
86
			$this->requete['join'][$join] = $join;
87
		}
87
		}
Line 88... Line 88...
88
	}
88
	}
89
 
89
 
Line 96... Line 96...
96
	}
96
	}
Line 97... Line 97...
97
 
97
 
98
	private function addWhere($idParam, $where) {
98
	private function addWhere($idParam, $where) {
99
		if (isset($this->parametres['_parametres_condition_or_'])
99
		if (isset($this->parametres['_parametres_condition_or_'])
-
 
100
				&& in_array($idParam, $this->parametres['_parametres_condition_or_'])) {
-
 
101
			if ($this->etreAppliImg() && in_array($idParam, $this->champsSousRequeteObs)) {
-
 
102
				$this->requete['where']['OR_SOUS_REQUETE'][] = $where;
100
				&& in_array($idParam, $this->parametres['_parametres_condition_or_'])) {
103
			} else {
-
 
104
				$this->requete['where']['OR'][] = $where;
101
			$this->requete['where']['OR'][] = $where;
105
			}
102
		} else {
106
		} else {
103
			$this->requete['where']['AND'][] = $where;
107
			$this->requete['where']['AND'][] = $where;
104
		}
108
		}
-
 
109
	}
105
	}
110
 
-
 
111
	public function getWhere() {
-
 
112
		// Sous-requete spéciale pour éviter de rechercher dans la table obs jointe à img depuis Pictoflora...
-
 
113
		if (isset($this->requete['where']['OR_SOUS_REQUETE']) && count($this->requete['where']['OR_SOUS_REQUETE']) > 0) {
-
 
114
			$clauseWhereSousRequete = implode(' OR ', $this->requete['where']['OR_SOUS_REQUETE']);
-
 
115
			$sousRequete = 'di.ce_observation IN '.
-
 
116
				"(SELECT DISTINCT id_observation FROM del_observation AS do WHERE $clauseWhereSousRequete ) ";
-
 
117
			$this->requete['where']['OR'][] = "( $sousRequete )";
-
 
118
			unset($this->requete['join']['LEFT JOIN del_observation AS do ON (di.ce_observation = do.id_observation) ']);
-
 
119
		}
106
	public function getWhere() {
120
 
107
		if (isset($this->requete['where']['OR']) && count($this->requete['where']['OR']) > 0) {
121
		if (isset($this->requete['where']['OR']) && count($this->requete['where']['OR']) > 0) {
108
			$this->requete['where']['AND'][] = '('.implode(' OR ', $this->requete['where']['OR']).')';
122
			$this->requete['where']['AND'][] = '('.implode(' OR ', $this->requete['where']['OR']).')';
Line 109... Line 123...
109
		}
123
		}
Line 448... Line 462...
448
			if (isset($this->parametres['masque.tag_cel']['AND'])) {
462
			if (isset($this->parametres['masque.tag_cel']['AND'])) {
449
				$tags = $this->parametres['masque.tag_cel']['AND'];
463
				$tags = $this->parametres['masque.tag_cel']['AND'];
450
				$clausesWhere = array();
464
				$clausesWhere = array();
451
				foreach ($tags as $tag) {
465
				foreach ($tags as $tag) {
452
					$tagMotif = $this->bdd->proteger("%$tag%");
466
					$tagMotif = $this->bdd->proteger("%$tag%");
-
 
467
					if ($this->etreAppliImg()) {
-
 
468
						$sousRequete = 'SELECT DISTINCT id_observation '.
-
 
469
							'FROM del_observation '.
-
 
470
							"WHERE mots_cles_texte LIKE $tagMotif ";
453
					$sqlTpl = "CONCAT(IFNULL(do.mots_cles_texte,''),IFNULL(di.mots_cles_texte,'')) LIKE %s";
471
						$sql = " (di.mots_cles_texte LIKE $tagMotif OR di.id_image IN ($sousRequete) ) ";
-
 
472
					} else {
-
 
473
						// WARNING : la sous-requête est la meilleure solution trouvée pour contrer le fonctionnement
-
 
474
						// étrange de l'optimiseur de MYSQL 5.6 (à retester avec Mysql 5.7 et suivant).
-
 
475
						$sousRequete = 'SELECT DISTINCT ce_observation '.
-
 
476
							'FROM del_image '.
-
 
477
							"WHERE mots_cles_texte LIKE $tagMotif ".
-
 
478
							'AND ce_observation IS NOT NULL';
-
 
479
						$sql = " (do.mots_cles_texte LIKE $tagMotif OR do.id_observation IN ($sousRequete)) ";
-
 
480
					}
454
					$clausesWhere[] = sprintf($sqlTpl, $tagMotif);
481
					$clausesWhere[] = $sql;
455
				}
482
				}
456
				$whereTags = implode(' AND ', $clausesWhere);
483
				$whereTags = implode(' AND ', $clausesWhere);
457
				$this->addWhere('masque.tag_cel', "($whereTags)");
484
				$this->addWhere('masque.tag_cel', "($whereTags)");
458
			} else if (isset($this->parametres['masque.tag_cel']['OR'])) {
485
			} else if (isset($this->parametres['masque.tag_cel']['OR'])) {
459
				$tags = $this->parametres['masque.tag_cel']['OR'];
486
				$tags = $this->parametres['masque.tag_cel']['OR'];
460
				$sqlTpl = "CONCAT(IFNULL(do.mots_cles_texte,''),IFNULL(di.mots_cles_texte,'')) REGEXP %s";
-
 
461
				$tagMotif = $this->bdd->proteger(implode('|', $tags));
487
				$tagMotif = $this->bdd->proteger(implode('|', $tags));
-
 
488
				$sqlTpl = "CONCAT(IFNULL(do.mots_cles_texte,''),IFNULL(di.mots_cles_texte,'')) REGEXP %s";
462
				$tagSql = sprintf($sqlTpl, $tagMotif);
489
				$tagSql = sprintf($sqlTpl, $tagMotif);
-
 
490
 
463
				$this->addWhere('masque.tag_cel', $tagSql);
491
				$this->addWhere('masque.tag_cel', $tagSql);
-
 
492
 
-
 
493
				if ($this->etreAppliObs()) {
-
 
494
					$this->addJoin('LEFT JOIN del_image AS di ON (di.ce_observation = do.id_observation) ');
-
 
495
				}
464
			}
496
			}
465
			if ($this->etreAppliImg()) {
497
			if ($this->etreAppliImg()) {
466
				$this->addJoin('LEFT JOIN del_observation AS do ON (di.ce_observation = do.id_observation) ');
498
				$this->addJoin('LEFT JOIN del_observation AS do ON (di.ce_observation = do.id_observation) ');
467
			}
499
			}
468
			if ($this->etreAppliObs()) {
-
 
469
				$this->addJoin('LEFT JOIN del_image AS di ON (do.id_observation = di.ce_observation) ');
-
 
470
			}
-
 
471
		}
500
		}
472
	}
501
	}
Line 473... Line 502...
473
 
502
 
474
	/**
503
	/**
475
	 * Plusieurs solutions sont disponibles dans les anciennes versions (voir DelTk et l'historique SVN de ce fichier).
504
	 * Plusieurs solutions sont disponibles dans les anciennes versions (voir DelTk et l'historique SVN de ce fichier).
476
	 */
505
	 */
477
	private function ajouterContrainteTagDel() {
506
	private function ajouterContrainteTagDel() {
478
		if (isset($this->parametres['masque.tag_del'])) {
-
 
479
			if (isset($this->parametres['masque.tag_del']['AND'])) {
507
		if (isset($this->parametres['masque.tag_del'])) {
480
				$tags = $this->parametres['masque.tag_del']['AND'];
-
 
481
				// optimisation: en cas de "AND" on sort() l'input et le GROUP_CONCAT()
-
 
482
				// donc nous utilisons des ".*" plutôt que de multiples conditions et "|"
-
 
483
				sort($tags);
508
			$tagsMotif = $this->construireTagsMotif();
484
				$tagsMotif = $this->bdd->proteger(implode('.*', $tags));
509
			if (is_null($tagsMotif) === false) {
485
				$requete = 'SELECT ce_image '.
510
				$sousRequete = 'SELECT ce_image '.
486
					'FROM del_image_tag '.
511
					'FROM del_image_tag '.
487
					'WHERE actif = 1 '.
512
					'WHERE actif = 1 '.
488
					'GROUP BY ce_image '.
513
					'GROUP BY ce_image '.
489
					"HAVING GROUP_CONCAT(tag_normalise ORDER BY tag_normalise) REGEXP $tagsMotif ".
-
 
490
					' -- '.__FILE__.' : '.__LINE__;
-
 
491
				$sql = $this->recupererSqlContrainteTag($requete);
-
 
492
				$this->addWhere('masque.tag_del', $sql);
-
 
493
 
-
 
494
			} else if (isset($this->parametres['masque.tag_del']['OR'])) {
-
 
495
				$tags = $this->parametres['masque.tag_del']['OR'];
-
 
496
				$tagsMotif = $this->bdd->proteger(implode('|', $tags));
-
 
497
				$requete = 'SELECT ce_image '.
-
 
498
					'FROM del_image_tag '.
-
 
499
					'WHERE actif = 1 '.
-
 
500
					'GROUP BY ce_image '.
-
 
501
					"HAVING GROUP_CONCAT(tag_normalise) REGEXP $tagsMotif ".
-
 
Line 502... Line -...
502
					' -- '.__FILE__.' : '.__LINE__;
-
 
503
 
514
					"HAVING GROUP_CONCAT(DISTINCT tag_normalise ORDER BY tag_normalise) REGEXP $tagsMotif ";
504
				$sql = $this->recupererSqlContrainteTag($requete);
515
 
505
				$this->addWhere('masque.tag_del', $sql);
516
				$this->addWhere('masque.tag_del', "di.id_image IN ($sousRequete)");
506
			}
517
			}
Line 507... Line 518...
507
		}
518
		}
508
	}
-
 
509
 
519
	}
510
	private function recupererSqlContrainteTag($requete) {
520
 
511
		$resultats = $this->bdd->recupererTous($requete);
521
	private function construireTagsMotif() {
512
		$ids = array();
-
 
513
		foreach ($resultats as $resultat) {
-
 
-
 
522
		$tagsMotif = null;
-
 
523
		if (isset($this->parametres['masque.tag_del']['AND'])) {
514
			$ids[] = $resultat['ce_image'];
524
			$tags = $this->parametres['masque.tag_del']['AND'];
515
		}
525
			// ATTENTION -> optimisation: en cas de "AND" on sort() l'input et le GROUP_CONCAT()
516
 
526
			// donc nous utilisons des ".*" plutôt que de multiples conditions et "|"
517
		if (!empty($ids)) {
527
			sort($tags);
-
 
528
			$tagsMotif = $this->bdd->proteger(implode('.*', $tags));
518
			$clauseIn = implode(',', $ids);
529
		} else if (isset($this->parametres['masque.tag_del']['OR'])) {
519
		} else {
530
			$tags = $this->parametres['masque.tag_del']['OR'];
520
			$clauseIn = 'SELECT ce_image FROM del_image_tag WHERE false';
531
			$tagsMotif = $this->bdd->proteger(implode('|', $tags));
Line 521... Line 532...
521
		}
532
		}
522
		return "di.id_image IN ($clauseIn)";
533
		return $tagsMotif;
523
	}
534
	}