48,7 → 48,7 |
$this->ajouterFiltreMasque('nom_sci', $val); |
break; |
case 'masque.nt' : |
$this->requete_condition[] = "num_tax IN ($val)"; |
$this->requete_condition[] = "num_taxonomique IN ($val)"; |
$this->masque[] = "num_tax=$val"; |
break; |
case 'masque.rg': |
64,7 → 64,7 |
public function gererNumTax() { |
if (!in_array('num_taxonomique', $this->champs_table)) { |
$this->presence_num_tax = false; |
$this->requete_champ = str_replace(', num_tax ', '', $this->requete_champ); |
$this->requete_champ = str_replace(', num_taxonomique ', '', $this->requete_champ); |
} else { |
$this->presence_num_tax = true; |
} |
100,7 → 100,7 |
if (strrpos($this->ressources[0], 'nt:') !== false) { |
if ($this->presence_num_tax) { |
// SELECT num_nom FROM bdtfx_v2_00 WHERE num_nom = num_nom_retenu AND num_taxonomique = X; |
$this->requete_condition[0] = ' num_tax = ' |
$this->requete_condition[0] = ' num_taxonomique = ' |
.str_replace('nt:', '', $this->ressources[0]).' '; |
} else { |
$e = 'Erreur dans votre requête : </br> Le numéro taxonomique n\'existe pas dans ce projet'; |
151,11 → 151,6 |
$this->format_reponse .= '/inferieurs'; |
$this->traiterRessourceIdRelationInfSup($rel); |
break; |
case 'hierarchie' : |
$rel = 'recupererIdHierarchie'; |
$this->format_reponse .= '/hierarchie'; |
$this->traiterRessourceIdRelationHierarchie($rel); |
break; |
default : |
$e = 'Erreur dans votre requête </br> Ressources disponibles : <br/> |
<li> taxons/#id/relations </li><li> #id/relations/inferieurs </li> |
166,39 → 161,6 |
} |
} |
|
public function traiterRessourceIdRelationHierarchie($rel) { |
//Appel de la fct récupérerIdSup ou recupererIdInf : retourne les num_nom des noms inferieurs ou superieurs |
$res_relation = $this->$rel(); |
//analyse du résultat retourné par la requete de recherche des identifiants correspondant aux taxons inf|sup : |
if ($res_relation == '') { |
//dans le cas ou la requete comporte des erreurs |
$e = 'Fct traiterRessourceIdRelationInfSup : La requête forme comporte une erreur!'; |
$this->renvoyerErreur(RestServeur::HTTP_CODE_RESSOURCE_INTROUVABLE, $e); |
} elseif ($res_relation) { |
//dans le cas ou une ou plusieurs relations est retournée, on récupère les identifiants ss la forme (id, id, id) |
foreach ($res_relation as $ligne) $res[] = $ligne['num_nom']; |
$res = implode(',',$res); |
$this->requete_condition[0] = "num_nom IN ($res)"; |
$this->requete_champ .= ', rang, num_tax_sup '; |
} else { //dans le cas ou aucune relation n'existe |
$res = array($this->num_nom_taxon => null); |
$this->corps_http = json_encode($res); |
$this->entete_http = RestServeur::HTTP_CODE_OK; |
} |
} |
|
public function recupererIdHierarchie() { |
$req_relation = 'SELECT num_nom FROM '.$this->table.' '. |
' WHERE hierarchie LIKE CONCAT('. |
'(SELECT hierarchie FROM '. |
$this->table.' '. |
'WHERE num_nom = '.$this->getBdd()->proteger($this->num_nom_taxon).')'. |
', '.$this->getBdd()->proteger($this->num_nom_taxon.'-%'). |
')'; |
$res_relation = $this->getBdd()->recupererTous($req_relation); |
return $res_relation; |
} |
|
public function traiterRessourceIdRelationInfSup($rel) { |
//Appel de la fct récupérerIdSup ou recupererIdInf : retourne les num_nom des noms inferieurs ou superieurs |
$res_relation = $this->$rel(); |
324,10 → 286,6 |
case 'taxons/id/relations/inferieurs' : |
$reponse = $this->formaterIdInferieur($resultat); |
break; |
case 'taxons/id/relations/hierarchie' : |
// le formatage de la hiérarchie est identique aux relations inférieures |
$reponse = $this->formaterIdInferieur($resultat); |
break; |
case 'taxons/stats/annees' : //ds CommunNomsTaxons |
$reponse = $this->formaterStatsAnnee($resultat); |
break; |