function genDateTri() { global $msg, $dbh, $charset, $PMBusername; if (SESSrights & ADMINISTRATION_AUTH) { $result .= "<h3>" . htmlentities($msg["gen_date_tri_msg"], ENT_QUOTES, $charset) . "</h3>"; $query = mysql_query("select notice_id, year, niveau_biblio, niveau_hierar from notices order by notice_id"); if (mysql_num_rows($query)) { while ($mesNotices = mysql_fetch_assoc($query)) { switch ($mesNotices['niveau_biblio'] . $mesNotices['niveau_hierar']) { case 'a2': //Si c'est un article, on récupère la date du bulletin associé $reqAnneeArticle = "SELECT date_date FROM bulletins, analysis WHERE analysis_bulletin=bulletin_id AND analysis_notice='" . $mesNotices['notice_id'] . "'"; $queryArt = mysql_query($reqAnneeArticle, $dbh); if (!mysql_num_rows($queryArt)) { $dateArt = ""; } else { $dateArt = mysql_result($queryArt, 0, 0); } if ($dateArt == '0000-00-00' || !isset($dateArt) || $dateArt == "") { $annee_art_tmp = ""; } else { $annee_art_tmp = substr($dateArt, 0, 4); } //On met à jour, les notices avec la date de parution et l'année $reqMajArt = "UPDATE notices SET date_parution='" . $dateArt . "', year='" . $annee_art_tmp . "'\n\t\t\t\t\t\t\t\t\t\tWHERE notice_id='" . $mesNotices['notice_id'] . "'"; mysql_query($reqMajArt, $dbh); break; case 'b2': //Si c'est une notice de bulletin, on récupère la date pour connaitre l'année $reqAnneeBulletin = "SELECT date_date FROM bulletins WHERE num_notice='" . $mesNotices['notice_id'] . "'"; $queryAnnee = mysql_query($reqAnneeBulletin, $dbh); if (!mysql_num_rows($queryAnnee)) { $dateBulletin = ""; } else { $dateBulletin = mysql_result($queryAnnee, 0, 0); } if ($dateBulletin == '0000-00-00' || !isset($dateBulletin) || $dateBulletin == "") { $annee_tmp = ""; } else { $annee_tmp = substr($dateBulletin, 0, 4); } //On met à jour date de parution et année $reqMajBull = "UPDATE notices SET date_parution='" . $dateBulletin . "', year='" . $annee_tmp . "'\n\t\t\t\t\t\t\t\t\tWHERE notice_id='" . $mesNotices['notice_id'] . "'"; mysql_query($reqMajBull, $dbh); break; default: // Mise à jour du champ date_parution des notices (monographie et pério) $date_parution = notice::get_date_parution($mesNotices['year']); $reqMaj = "UPDATE notices SET date_parution='" . $date_parution . "' WHERE notice_id='" . $mesNotices['notice_id'] . "'"; mysql_query($reqMaj, $dbh); break; } } mysql_free_result($query); } $not = mysql_query("SELECT count(1) FROM notices", $dbh); $count = mysql_result($not, 0, 0); $result .= $count . " " . htmlentities($msg['gen_date_tri_msg'], ENT_QUOTES, $charset); } else { $result .= sprintf($msg["planificateur_rights_bad_user_rights"], $PMBusername); } return $result; }
function update_in_database($id_notice = 0) { global $dbh; global $pmb_synchro_rdf; $new_notice = 2; $notice_retour = $id_notice; if (!$id_notice) { $retour = array(2, 0); return $retour; } //synchro_rdf if ($pmb_synchro_rdf) { $synchro_rdf = new synchro_rdf(); $synchro_rdf->delRdf($notice_retour, 0); } // traitement des titres uniformes global $pmb_use_uniform_title; if ($pmb_use_uniform_title) { if (count($this->titres_uniformes)) { $ntu = new tu_notice($id_notice); $ntu->update($this->titres_uniformes); } } for ($i = 0; $i < 2; $i++) { if ($this->editors[$i]['id']) { $editor_ids[$i] = $this->editors[$i]['id']; } else { $editor_ids[$i] = editeur::import($this->editors[$i]); } } if ($this->collection["id"]) { $collection_id = $this->collection["id"]; } else { $this->collection['parent'] = $editor_ids[0]; $collection_id = collection::import($this->collection); } if ($this->subcollection["id"]) { $subcollection_id = $this->subcollection["id"]; } else { $this->subcollection['coll_parent'] = $collection_id; $subcollection_id = subcollection::import($this->subcollection); $serie_id = serie::import(stripslashes($this->serie)); } /* traitement de Dewey */ if (!$this->internal_index) { if (!$this->dewey["new_comment"]) { $this->dewey["new_comment"] = ""; } if (!$this->dewey["new_pclass"]) { $this->dewey["new_pclass"] = ""; } $this->internal_index = indexint::import(clean_string($this->dewey[0]), clean_string($this->dewey["new_comment"]), clean_string($this->dewey["new_pclass"])); } $date_parution_z3950 = notice::get_date_parution($this->year); /* Origine de la notice */ $this->orinot_id = origine_notice::import($this->origine_notice); if ($this->orinot_id == 0) { $this->orinot_id = 1; } $sql_ins = "update notices set\n\t\t\ttypdoc \t='" . $this->document_type . "',\n\t\t\tcode \t ='" . $this->isbn . "',\t \n\t\t\ttit1 ='" . $this->titles[0] . "', \n\t\t\ttit2 ='" . $this->titles[1] . "', \n\t\t\ttit3 ='" . $this->titles[2] . "', \n\t\t\ttit4 ='" . $this->titles[3] . "', \n\t\t\ttparent_id ='" . $serie_id . "', \n\t\t\ttnvol ='" . $this->nbr_in_serie . "', \n\t\t\ted1_id =" . $editor_ids[0] . " , \n\t\t\ted2_id =" . $editor_ids[1] . " , \n\t\t\tyear ='" . $this->year . "', \n\t\t\tnpages ='" . $this->page_nbr . "', \n\t\t\till ='" . $this->illustration . "', \n\t\t\tsize ='" . $this->size . "', \n\t\t\taccomp ='" . $this->accompagnement . "', \n\t\t\tcoll_id =" . $collection_id . " , \n\t\t\tsubcoll_id =" . $subcollection_id . " , \n\t\t\tnocoll ='" . $this->nbr_in_collection . "', \n\t\t\tmention_edition ='" . $this->mention_edition . "', \n\t\t\tn_gen ='" . $this->general_note . "', \n\t\t\tn_contenu ='" . $this->content_note . "', \n\t\t\tn_resume ='" . $this->abstract_note . "', \n\t\t\tindexint ='" . $this->internal_index . "', \n\t\t\tstatut\t\t\t\t\t='" . $this->statut . "',\n\t\t\tcommentaire_gestion\t\t='" . $this->commentaire_gestion . "',\n\t\t\tindexation_lang\t\t\t='" . $this->indexation_lang . "',\n\t\t\tthumbnail_url\t\t\t='" . $this->thumbnail_url . "',\n\t\t\tindex_l ='" . clean_tags($this->free_index) . "', \n\t\t\tniveau_biblio ='" . $this->bibliographic_level . "', \n\t\t\tniveau_hierar ='" . $this->hierarchic_level . "', \n\t\t\tlien ='" . $this->link_url . "', \n\t\t\teformat ='" . $this->link_format . "', \n\t\t\torigine_catalogage ='" . $this->orinot_id . "', \n\t\t\tprix ='" . $this->prix . "',\n\t\t\tdate_parution \t\t\t='" . $date_parution_z3950 . "' \n\t\t\twhere notice_id='{$id_notice}' "; //echo "<pre>"; //print_r($this->aut_array); //echo "</pre>"; //echo $sql_ins."<br />"; //echo "<pre>"; //print_r($this->categories); //echo "</pre>"; //exit; $sql_result_ins = pmb_mysql_query($sql_ins) or die("Couldn't update notices : " . $sql_ins); $notice_retour = $id_notice; audit::insert_modif(AUDIT_NOTICE, $id_notice); // purge de la base des responsabilités de la notice intégrée... if ($notice_retour) { $rqt_del = "delete from responsability where responsability_notice='{$notice_retour}'"; $sql_result_del = pmb_mysql_query($rqt_del) or die("Couldn't purge table responsability : " . $rqt_del); } $rqt_ins = "insert into responsability (responsability_author, responsability_notice, responsability_fonction, responsability_type, responsability_ordre) VALUES "; for ($i = 0; $i < sizeof($this->aut_array); $i++) { $aut['id'] = clean_string($this->aut_array[$i]['id']); $aut['name'] = clean_string($this->aut_array[$i]['entree']); $aut['rejete'] = clean_string($this->aut_array[$i]['rejete']); $aut['date'] = clean_string($this->aut_array[$i]['date']); $aut['type'] = $this->aut_array[$i]['type_auteur']; $aut['subdivision'] = clean_string($this->aut_array[$i]['subdivision']); $aut['numero'] = clean_string($this->aut_array[$i]['numero']); $aut['lieu'] = clean_string($this->aut_array[$i]['lieu']); $aut['ville'] = clean_string($this->aut_array[$i]['ville']); $aut['pays'] = clean_string($this->aut_array[$i]['pays']); $aut['web'] = clean_string($this->aut_array[$i]['web']); $aut['author_comment'] = clean_string($this->aut_array[$i]['author_comment']); $aut['authority_number'] = clean_string($this->aut_array[$i]['authority_number']); /* Origine de l'autorité : on reprend les infos d'origine de la notice pour les attribuées aux origines des autorités */ $id_origine_auth = 0; $id_origine_auth = origin_authorities::import($this->origine_notice); if ($id_origine_auth == 0) { $id_origine_auth = 1; } // import de l'autorité auteur si elle n'existe pas et conservation des infos sur l'origine de l'autorité if ($aut['authority_number'] != '' && $id_origine_auth) { $this->aut_array[$i]["id"] = $this->insert_authority_infos($aut['authority_number'], "author", $id_origine_auth, $aut); } if (!$this->aut_array[$i]["id"]) { $this->aut_array[$i]["id"] = auteur::import($aut); } if ($this->aut_array[$i]["id"]) { $rqt = $rqt_ins . " (" . $this->aut_array[$i]["id"] . "," . $notice_retour . ",'" . $this->aut_array[$i]['fonction'] . "'," . $this->aut_array[$i]['responsabilite'] . "," . $i . ") "; $res_ins = pmb_mysql_query($rqt, $dbh); } } // traitement des categories if ($this->categorisation_type == "categorisation_auto") { traite_categories_enreg($notice_retour, $this->categories); } else { $rqt_del = "delete from notices_categories where notcateg_notice='{$notice_retour}' "; $res_del = @pmb_mysql_query($rqt_del, $dbh); $rqt_ins = "insert into notices_categories (notcateg_notice, num_noeud, ordre_categorie) VALUES "; $rqt_ins_values = array(); foreach ($this->categories as $i => $category) { $id_categ = $category['categ_id']; if ($id_categ) { $rqt_ins_values[] = " ('{$notice_retour}','{$id_categ}', {$i}) "; } } $rqt_ins .= implode(",", $rqt_ins_values); $res_ins = @pmb_mysql_query($rqt_ins, $dbh); } // traitement des langues // langues de la publication $rqt_del = "delete from notices_langues where num_notice='{$notice_retour}' "; $res_del = pmb_mysql_query($rqt_del, $dbh); if (is_array($this->language_code) && count($this->language_code)) { $rqt_ins = "insert into notices_langues (num_notice, type_langue, code_langue, ordre_langue) VALUES "; foreach ($this->language_code as $ordre_lang => $code_lang) { if ($code_lang) { $rqt = $rqt_ins . " ('{$notice_retour}',0, '{$code_lang}', {$ordre_lang}) "; $res_ins = @pmb_mysql_query($rqt, $dbh); } } } // langues originales if (is_array($this->original_language_code) && count($this->original_language_code)) { $rqt_ins = "insert into notices_langues (num_notice, type_langue, code_langue, ordre_langue) VALUES "; foreach ($this->original_language_code as $ordre_lang => $code_lang) { if ($code_lang) { $rqt = $rqt_ins . " ('{$notice_retour}',1, '{$code_lang}', {$ordre_lang}) "; $res_ins = @pmb_mysql_query($rqt, $dbh); } } } //Traitement des champs personnalisés (du formulaire !!!) $p_perso = new parametres_perso("notices"); $nberrors = $p_perso->check_submited_fields(); $p_perso->rec_fields_perso($notice_retour); //Traitement import perso global $notice_id, $notice_org, $notice_type_org; if (function_exists('z_recup_noticeunimarc_suite') && function_exists('recup_noticeunimarc_suite')) { //Suppression des champs persos $requete = "delete from notices_custom_values where notices_custom_origine=" . $notice_retour; @pmb_mysql_query($requete); $notice_id = $notice_retour; z_recup_noticeunimarc_suite($notice_org); z_import_new_notice_suite(); } // Mise à jour des index de la notice notice::majNotices($notice_retour); // Mise à jour de la table notices_global_index notice::majNoticesGlobalIndex($notice_retour); // Mise à jour de la table notices_mots_global_index notice::majNoticesMotsGlobalIndex($notice_retour); //Documents numériques foreach ($this->doc_nums as $doc_num) { if (!$doc_num["a"]) { continue; } explnum_add_from_url($notice_retour, $this->bull_id, $doc_num["b"], $doc_num["a"], false, $this->source_id, $doc_num["f"], '', $doc_num["s"]); } //synchro_rdf if ($pmb_synchro_rdf) { $synchro_rdf->addRdf($notice_retour, 0); } $retour = array($new_notice, $notice_retour); return $retour; }
$f_categ[] = array('id' => ${$var_categid}, 'ordre' => $order); $order++; } } } else { for ($i = 0; $i < $max_categ; $i++) { $var_categid = "f_categ_id{$i}"; $f_categ[] = array('id' => ${$var_categid}, 'ordre' => $i); } } $f_indexint ? $t_notice['indexint'] = $f_indexint_id : ($t_notice['indexint'] = 0); $f_lien ? $t_notice['lien'] = $f_lien : ($t_notice['lien'] = ''); $t_notice['lien'] && $f_eformat ? $t_notice['eformat'] = $f_eformat : ($t_notice['eformat'] = ''); $b_level ? $t_notice['b_level'] = $b_level : ($t_notice['b_level'] = 'm'); $h_level ? $t_notice['h_level'] = $h_level : ($t_notice['h_level'] = '0'); $date_parution_notice = notice::get_date_parution($t_notice['year']); //Champ signature $t_notice['signature'] = $signature; $t_notice['indexation_lang'] = $indexation_lang; $requete .= " typdoc='{$t_notice['typdoc']}'"; $requete .= ", tit1='{$t_notice['tit1']}'"; $requete .= ", tit2='{$t_notice['tit2']}'"; $requete .= ", tit3='{$t_notice['tit3']}'"; $requete .= ", tit4='{$t_notice['tit4']}'"; $requete .= ", tparent_id={$t_notice['tparent_id']}"; $requete .= ", tnvol='{$t_notice['tnvol']}'"; $requete .= ", ed1_id='{$t_notice['ed1_id']}'"; $requete .= ", ed2_id='{$t_notice['ed2_id']}'"; $requete .= ", coll_id='{$t_notice['coll_id']}'"; $requete .= ", subcoll_id='{$t_notice['subcoll_id']}'"; $requete .= ", year='{$t_notice['year']}'";
function notice($id = 0, $cb = '') { global $dbh; global $msg; global $include_path, $class_path; global $deflt_notice_is_new; //On nettoie la variable de liens entre notices $this->notice_link = array(); if ($id) { $fonction = new marc_list('function'); $this->id = $id; $this->libelle_form = $msg[278]; // libelle du form : modification d'une notice $requete = "SELECT * FROM notices WHERE notice_id='{$id}' LIMIT 1 "; $result = @pmb_mysql_query($requete, $dbh); if ($result) { $notice = pmb_mysql_fetch_object($result); $this->type_doc = $notice->typdoc; // type du document $this->tit1 = $notice->tit1; // titre propre $this->tit2 = $notice->tit2; // titre propre 2 $this->tit3 = $notice->tit3; // titre parallele $this->tit4 = $notice->tit4; // complement du titre $this->tparent_id = $notice->tparent_id; // id du titre parent // libelle du titre parent if ($this->tparent_id) { $serie = new serie($this->tparent_id); $this->tparent = $serie->name; } else { $this->tparent = ''; } $this->tnvol = $notice->tnvol; // numero de partie $this->responsabilites = get_notice_authors($this->id); $this->subcoll_id = $notice->subcoll_id; // id sous collection $this->coll_id = $notice->coll_id; // id collection $this->ed1_id = $notice->ed1_id; // id editeur 1 require_once "{$class_path}/editor.class.php"; if ($this->subcoll_id) { require_once "{$class_path}/subcollection.class.php"; require_once "{$class_path}/collection.class.php"; $collection = new subcollection($this->subcoll_id); $this->subcoll = $collection->name; } if ($this->coll_id) { require_once "{$class_path}/collection.class.php"; $collection = new collection($this->coll_id); $this->coll = $collection->name; } if ($this->ed1_id) { $editeur = new editeur($this->ed1_id); $this->ed1 = $editeur->display; } $this->year = $notice->year; // annee de publication $this->nocoll = $notice->nocoll; // no. dans la collection $this->mention_edition = $notice->mention_edition; // mention d'edition (1ere, deuxieme...) $this->ed2_id = $notice->ed2_id; // id editeur 2 if ($this->ed2_id) { // libelle editeur 2 $editeur = new editeur($this->ed2_id); $this->ed2 = $editeur->display; } $this->code = $notice->code; // ISBN, code barre commercial ou no. commercial $this->npages = $notice->npages; // importance materielle (nombre de pages, d'elements...) $this->ill = $notice->ill; // mention d'illustration $this->size = $notice->size; // format $this->prix = $notice->prix; // Prix du document $this->accomp = $notice->accomp; // materiel d'accompagnement $this->n_gen = $notice->n_gen; // note generale $this->n_contenu = $notice->n_contenu; // note de contenu $this->n_resume = $notice->n_resume; // resume/extrait $this->categories = get_notice_categories($this->id); $this->indexint = $notice->indexint; // indexation interne $this->index_l = $notice->index_l; // indexation libre $this->langues = get_notice_langues($this->id, 0); // langues de la publication $this->languesorg = get_notice_langues($this->id, 1); // langues originales $this->lien = $notice->lien; // URL de la ressource electronique associee $this->eformat = $notice->eformat; // format de la ressource electronique associee $this->biblio_level = $notice->niveau_biblio; // niveau bibliographique $this->hierar_level = $notice->niveau_hierar; // niveau hierarchique $this->statut = $notice->statut; $this->date_parution = notice::get_date_parution($notice->year); $this->indexation_lang = $notice->indexation_lang; $this->is_new = $notice->notice_is_new; $this->date_is_new = $notice->notice_date_is_new; //liens vers autres notices $requete = "SELECT * FROM notices_relations WHERE num_notice=" . $this->id . " OR linked_notice=" . $this->id . " order by rank"; $result_rel = pmb_mysql_query($requete); if (pmb_mysql_num_rows($result_rel)) { $i = 0; while ($r_rel = pmb_mysql_fetch_object($result_rel)) { if ($r_rel->linked_notice == $this->id) { //notice en cours est notice fille $this->notice_link['down'][$i]['relation_direction'] = 'down'; $this->notice_link['down'][$i]['id_notice'] = $r_rel->num_notice; $this->notice_link['down'][$i]['title_notice'] = $this->get_notice_title($r_rel->num_notice); $this->notice_link['down'][$i]['rank'] = $r_rel->rank; $this->notice_link['down'][$i]['relation_type'] = $r_rel->relation_type; } elseif ($r_rel->num_notice == $this->id) { //notice en cours est notice mere $this->notice_link['up'][$i]['relation_direction'] = 'up'; $this->notice_link['up'][$i]['id_notice'] = $r_rel->linked_notice; $this->notice_link['up'][$i]['title_notice'] = $this->get_notice_title($r_rel->linked_notice); $this->notice_link['up'][$i]['rank'] = $r_rel->rank; $this->notice_link['up'][$i]['relation_type'] = $r_rel->relation_type; } $i++; } } $this->commentaire_gestion = $notice->commentaire_gestion; $this->thumbnail_url = $notice->thumbnail_url; $this->create_date = $notice->create_date; $this->update_date = $notice->update_date; } else { require_once "{$include_path}/user_error.inc.php"; error_message("", $msg[280], 1, "./catalog.php"); $this->ok = 0; } return; } else { // initialisation des valeurs (vides) $this->libelle_form = $msg[270]; // libelle du form : creation d'une notice $this->id = 0; $this->code = $cb; // initialisation avec les parametres du user : global $value_deflt_lang, $value_deflt_relation; if ($value_deflt_lang) { $lang = new marc_list('lang'); $this->langues[] = array('lang_code' => $value_deflt_lang, 'langue' => $lang->table[$value_deflt_lang]); } global $deflt_notice_statut; if ($deflt_notice_statut) { $this->statut = $deflt_notice_statut; } else { $this->statut = 1; } global $xmlta_doctype; $this->type_doc = $xmlta_doctype; global $notice_parent; //relation montante ou descendante global $notice_parent_direction; if ($notice_parent) { if (!$notice_parent_direction) { // Si pas de sens, on force a relation descendante $notice_parent_direction = 'down'; } $this->notice_link[$notice_parent_direction][0]['relation_direction'] = $notice_parent_direction; $this->notice_link[$notice_parent_direction][0]['id_notice'] = $notice_parent; $this->notice_link[$notice_parent_direction][0]['title_notice'] = $this->get_notice_title($notice_parent); $this->notice_link[$notice_parent_direction][0]['rank'] = 1; //Recherche d'un type plausible $requete = "SELECT relation_type FROM notices_relations WHERE num_notice='{$notice_parent}' ORDER BY rank DESC LIMIT 1"; $resultat = pmb_mysql_query($requete); if (@pmb_mysql_num_rows($resultat)) { $this->notice_link[$notice_parent_direction][0]['relation_type'] = pmb_mysql_result($resultat, 0, 0); } elseif (preg_match('/' . $notice_parent_direction . '$/', $value_deflt_relation)) { $this->notice_link[$notice_parent_direction][0]['relation_type'] = $value_deflt_relation; } else { /* * Comment forcer le sens ? * peut-etre l'inverse de la valeur par defaut si celle-ci ne va pas dans le bon sens ... */ } } $this->is_new = $deflt_notice_is_new; // penser au test d'existence de la notice sur code-barre return; } }
function import_new_notice() { global $dbh; global $notice_id; global $bulletin_ex; //Identifiant du bulletin $bulletin_ex = 0; global $id_unimarc; global $notices_crees; global $bulletins_crees; global $notices_a_creer; global $bulletins_a_creer; global $base_path; global $pmb_keyword_sep; global $link_generate; global $doc_type; global $hierarchic_level; global $bibliographic_level; global $isbn_OK; global $prix; global $prix_cd; global $cb; global $tit_200a; global $tit_200c; global $tit_200d; global $tit_200e; global $tit_200v; global $serie_200; global $editor; global $editeur_lieu; global $editeur_adr; global $editeur_nom; global $editeur_date; global $editeur_pays; global $editeur_pmbfields; global $no_edition; global $npages; global $ill; global $size; global $accomp; global $collection_225; global $n_contenu; global $n_resume; global $n_gen; global $EAN; global $collection_410; global $collection_411; global $tu_500; global $tu_500_r; global $tu_500_s; global $tu_500_j; global $serie; global $index_sujets; global $dewey; global $dewey_l; global $aut_700; global $aut_701; global $aut_702; global $aut_710; global $aut_711; global $aut_712; global $origine_notice; global $lien; global $eformat; global $analytique; global $statutnot; global $indicateur; global $add_explnum; global $info_686; global $authorities_notices; global $authorities_default_origin; $origin_authority = $authorities_default_origin; $add_explnum = FALSE; /* traitement des éditeurs */ $coll_id = 0; $subcoll_id = 0; $serie_id = 0; $tnvol_ins = ""; $ed1_id = 0; $ed2_id = 0; $year = ""; $date_parution = "0000-00-00"; //On récupère le tableau des notices créées à partir du fichier temporaire (rechargement d'iframe) if ($link_generate && !isset($notices_crees)) { $tabimport_id = file_get_contents("{$base_path}/temp/liste_id" . SESSid . ".txt"); if ($tabimport_id) { $tabimport_id = unserialize($tabimport_id); $notices_crees = $tabimport_id['notices_existantes']; $notices_a_creer = $tabimport_id['notices_a_creer']; $bulletins_crees = $tabimport_id['bulletins_crees']; $bulletins_a_creer = $tabimport_id['bulletins_a_creer']; } } if (!is_array($notices_crees)) { $notices_crees = array(); } //Pour le cas ou on est sur une notice (bidon) d'article juste pour les exemplaires de bulletin if ($bibliographic_level == "a" && $tit_200d[0] == "Article_expl_bulletin") { //On importe rien return; } elseif ($tit_200d[0] == "Article_expl_bulletin") { //Pour le cas ou on import sans les liens un fichier exporter avec les exemplaires et les liens $tit_200d[0] = ""; } if ($bibliographic_level != "a" && $bibliographic_level != "b") { //Pour les articles et les bulletins on ne garde pas les informations suivantes $year = clean_string($editeur_date[0]); $date_parution = notice::get_date_parution($year); //traitement des éditeurs $editor = array(); foreach ($editeur_nom as $key_nom1 => $nom1) { foreach ($nom1 as $key_nom2 => $nom2) { $mon_ed = array(); $mon_ed["c"] = $nom2; if ($editeur_adr[$key_nom1][$key_nom2]) { $mon_ed["b"] = $editeur_adr[$key_nom1][$key_nom2]; } if ($editeur_lieu[$key_nom1][$key_nom2]) { $mon_ed["a"] = $editeur_lieu[$key_nom1][$key_nom2]; } if ($editeur_pays[$key_nom1][$key_nom2]) { $mon_ed["z"] = $editeur_pays[$key_nom1][$key_nom2]; } if ($editeur_pmbfields[$key_nom1][$key_nom2]) { //Si j'ai ces informations c'est un export PMB donc je n'ai pas deux editeurs dans le même 210 foreach ($editeur_pmbfields[$key_nom1] as $val9) { if (preg_match("/^(.+?):(.+)\$/", $val9, $matches)) { $mon_ed[trim($matches[1])] = $matches[2]; } } } $editor[] = $mon_ed; } } $ed = array(); $ed['name'] = clean_string($editor[0]['c']); $ed['adr'] = clean_string($editor[0]['b']); if ($editor[0]['adr1']) { $ed['adr'] = clean_string($editor[0]['adr1']); } //Si cela vient de PMB dans $b j'ai un concat $ed['ville'] = clean_string($editor[0]['a']); $ed['adr2'] = clean_string($editor[0]['adr2']); $ed['cp'] = clean_string($editor[0]['cp']); $ed['pays'] = clean_string($editor[0]['z']); $ed['web'] = clean_string($editor[0]['web']); $ed['ed_comment'] = clean_string($editor[0]['comment']); $ed1_id = editeur::import($ed); $ed = array(); $ed['name'] = clean_string($editor[1]['c']); $ed['adr'] = clean_string($editor[1]['b']); if ($editor[1]['adr1']) { $ed['adr'] = clean_string($editor[1]['adr1']); } //Si cela vient de PMB dans $b j'ai un concat $ed['ville'] = clean_string($editor[1]['a']); $ed['adr2'] = clean_string($editor[1]['adr2']); $ed['cp'] = clean_string($editor[1]['cp']); $ed['pays'] = clean_string($editor[1]['z']); $ed['web'] = clean_string($editor[1]['web']); $ed['ed_comment'] = clean_string($editor[1]['comment']); $ed2_id = editeur::import($ed); if ($bibliographic_level != "s") { //Pour les periodiques on ne garde pas les informations suivantes /* traitement des collections */ $coll_name = ""; $subcoll_name = ""; $coll_issn = ""; $subcoll_issn = ""; $nocoll_ins = ""; /* traitement de 225$a, si rien alors 410$t pour la collection */ if ($collection_225[0]['a'] != "") { $coll_name = $collection_225[0]['a']; $coll_issn = $collection_225[0]['x']; } elseif ($collection_410[0]['t'] != "") { $coll_name = $collection_410[0]['t']; $coll_issn = $collection_410[0]['x']; $coll_aut_number = $collection_410[0]['3']; } /* traitement de 225$i, si rien alors 411$t pour la sous-collection */ if ($collection_225[0]['i'] != "") { $subcoll_name = $collection_225[0]['i']; $subcoll_issn = $collection_225[1]['x']; } elseif ($collection_411[0]['t'] != "") { $subcoll_name = $collection_411[0]['t']; $subcoll_issn = $collection_411[0]['x']; $coll_aut_number = $collection_411[0]['3']; } /* gaffe au nocoll, en principe en 225$v selon FL sinon en 410$v ou 411$v*/ if ($collection_225[0]['v'] != "") { $nocoll_ins = $collection_225[0]['v']; } elseif ($collection_410[0]['v'] != "") { $nocoll_ins = $collection_410[0]['v']; } elseif ($collection_411[0]['v'] != "") { $nocoll_ins = $collection_411[0]['v']; } else { $nocoll_ins = ""; } $collec['name'] = clean_string($coll_name); $collec['parent'] = $ed1_id; $collec['issn'] = clean_string($coll_issn); $collec['authority_number'] = $coll_aut_number; if ($collec['authority_number']) { $coll_id = keep_authority_infos($collec['authority_number'], "collection", $origin_authority, 0, $collec); } else { $coll_id = collection::import($collec); } /* sous collection */ $subcollec['name'] = clean_string($subcoll_name); $subcollec['coll_parent'] = $coll_id; $subcollec['issn'] = clean_string($subcoll_issn); $subcollec['authority_number'] = $subcoll_aut_number; if ($subcollec['authority_number']) { $subcoll_id = keep_authority_infos($subcollec['authority_number'], "subcollection", $origin_authority, 0, $subcollec); } else { $subcoll_id = collection::import($subcollec); } $subcoll_id = subcollection::import($subcollec); /* traitement des séries */ $serie_id = serie::import(clean_string($serie[0]['t'])); $tnvol_ins = $serie[0]['v']; if (!$serie_id) { $serie_id = serie::import(clean_string($serie_200[0]['i'])); $serie[0]['t'] = $serie_200[0]['i']; //$tnvol_ins=$serie_200[0]['h']; } if (!$tnvol_ins) { $tnvol_ins = $serie_200[0]['h']; } } } /* traitement de Dewey */ $indexint_id = indexint::import(clean_string($dewey[0]), $dewey_l[0]); if (!$indexint_id and count($info_686)) { $indexint_id = indexint::import(clean_string($info_686[0]["a"]), $info_686[0]["l"], 99); } /* Traitement des notes */ $n_resume_total = ""; $n_gen_total = ""; $n_contenu_total = ""; if (!$n_resume) { $n_resume = array(); } $n_resume_total = implode("\n", $n_resume); if (!$n_gen) { $n_gen = array(); } $n_gen_total = implode("\n", $n_gen); if (!$n_contenu) { $n_contenu = array(); } $n_contenu_total = implode("\n", $n_contenu); // ajout : les 464$a sont ajouté aux notes de contenu à déporter éventuellement dans func_bdp41 si besoin for ($i = 0; $i < count($analytique); $i++) { $ana = array(); for ($j = 0; $j < count($analytique[$i]); $j++) { $ana[$analytique[$i][$j]["label"]][] = $analytique[$i][$j]["content"]; } if (count($ana["a"]) == 1) { //Selon la norme le $a n'est pas répétable dans le même champ 4XX $n_contenu_total .= $ana["a"][0] . (count($ana["e"]) ? " ; " . implode(" ; ", $ana["e"]) : "") . (count($ana["f"]) ? " / " . implode(" / ", $ana["f"]) : "") . (count($ana["g"]) ? " / " . implode(" / ", $ana["g"]) : "") . "\n"; } else { //Au cas où for ($j = 0; $j < count($ana["a"]); $j++) { $n_contenu_total .= $ana["a"][$j] . ($ana["e"][$j] ? " ; " . $ana["e"][$j] : "") . ($ana["f"][$j] ? " / " . $ana["f"][$j] : "") . ($ana["g"][$j] ? " / " . $ana["g"][$j] : "") . "\n"; } } } // Préparation des titres $tit[0]['a'] = implode(" ; ", $tit_200a); if ($bibliographic_level != "a" && $bibliographic_level != "b" && $bibliographic_level != "s") { //Pour les articles et les bulletins on ne garde pas les informations suivantes $tit[0]['c'] = implode(" ; ", $tit_200c); } else { $tit[0]['c'] = ""; } $tit[0]['d'] = implode(" ; ", $tit_200d); $tit[0]['e'] = implode(" ; ", $tit_200e); if (is_array($index_sujets)) { $index_l = implode(' ' . $pmb_keyword_sep . ' ', $index_sujets); } else { $index_l = $index_sujets; } // if (trim($n_resume_total)=="") $n_resume_total = $n_gen_total." ".$n_contenu_total ; /* Origine de la notice */ $origine_not['nom'] = clean_string($origine_notice[0]['b']); $origine_not['pays'] = clean_string($origine_notice[0]['a']); $orinot_id = origine_notice::import($origine_not); if ($orinot_id == 0) { $orinot_id = 1; } if ($bibliographic_level != "a" && $bibliographic_level != "s") { //Pour les articles et les periodiques on ne garde pas les informations suivantes // prix $price = $prix[0]; //Pour les CDs if (!$price) { $price = $prix_cd[0]; } $illustration = implode(" : ", $ill); $taille = implode(" ; ", $size); $mat_accomp = implode(" + ", $accomp); if ($bibliographic_level != "b") { $mention_edit = implode(", ", $no_edition); } else { $mention_edit = ""; } } else { $illustration = ""; $taille = ""; $mat_accomp = ""; } if ($bibliographic_level != "s") { //Pour les periodiques on ne garde pas les informations suivantes $nbpages = implode(" - ", $npages); } else { $nbpages = ""; } /* and at least, the insertion in notices table */ $sql_ins = "insert into notices (\n\t\t\t\t\t\ttypdoc\t\t\t,\n\t\t\t\t\t\tcode \t,\n\t\t\t\t\t\tstatut\t\t\t,\n\t\t tit1 ,\n\t\t tit2 ,\n\t\t tit3 ,\n\t\t tit4 ,\n\t\t tparent_id ,\n\t\t tnvol ,\n\t\t ed1_id ,\n\t\t ed2_id ,\n\t\t year ,\n\t\t npages ,\n\t\t ill ,\n\t\t size ,\n\t\t accomp ,\n\t\t coll_id ,\n\t\t subcoll_id ,\n\t\t nocoll ,\n\t\t mention_edition\t,\n\t\t n_gen ,\n\t\t n_contenu ,\n\t\t n_resume ,\n\t\t index_l,\n\t\t indexint,\n\t\t niveau_biblio,\n\t\t niveau_hierar,\n\t\t lien,\n\t\t eformat,\n\t\t origine_catalogage,\n\t\t prix,\n\t\t\t\t\t\tcreate_date,\n\t\t\t\t\t\tdate_parution\n\t\t\t\t) values (\n\t\t\t\t\t\t'" . $doc_type . "',\t\n\t\t\t\t\t\t'" . addslashes($isbn_OK) . "',\t\n\t\t\t\t\t\t'" . $statutnot . "',\n\t\t '" . addslashes(clean_string($tit[0]['a'])) . "',\n\t\t '" . addslashes(clean_string($tit[0]['c'])) . "',\n\t\t '" . addslashes(clean_string($tit[0]['d'])) . "',\n\t\t '" . addslashes(clean_string($tit[0]['e'])) . "',\n\t\t '" . $serie_id . "',\n\t\t '" . addslashes($tnvol_ins) . "',\n\t\t " . $ed1_id . " ,\n\t\t " . $ed2_id . " ,\n\t\t '" . addslashes($year) . "',\n\t\t '" . addslashes($nbpages) . "',\n\t\t '" . addslashes($illustration) . "',\n\t\t '" . addslashes($taille) . "',\n\t\t '" . addslashes($mat_accomp) . "',\n\t\t " . $coll_id . " ,\n\t\t " . $subcoll_id . " ,\n\t\t '" . addslashes($nocoll_ins) . "',\n\t\t '" . addslashes($mention_edit) . "',\n\t\t '" . addslashes($n_gen_total) . "',\n\t\t \t'" . addslashes($n_contenu_total) . "',\n\t\t \t'" . addslashes($n_resume_total) . "',\n\t\t '" . addslashes($index_l) . "',\n\t\t '" . $indexint_id . "',\n\t\t '" . $bibliographic_level . "',\n\t\t '" . $hierarchic_level . "',\n\t\t '" . addslashes($lien[0]) . "',\n\t\t '" . addslashes($eformat[0]) . "',\n\t\t '" . $orinot_id . "',\n\t\t '" . addslashes($price) . "',\n\t\t\t\t\t\tsysdate(),\n\t\t\t\t\t\t'" . addslashes($date_parution) . "'\n\t\t\t\t\t\t)"; mysql_query($sql_ins, $dbh) or die("Couldn't insert into notices ! = " . $sql_ins); $notice_id = mysql_insert_id($dbh); notice::majNotices($notice_id); audit::insert_creation(AUDIT_NOTICE, $notice_id); //calcul des droits d'accès s'ils sont activés calc_notice_acces_rights($notice_id); // on devait attendre que la notice soit intégrée pour faire l'association avec la notice..; if ($collec['authority_number']) { keep_authority_infos($collec['authority_number'], "scollection", $origin_authority, $notice_id, $collec); } if ($subcollec['authority_number']) { keep_authority_infos($subcollec['authority_number'], "subcollection", $origin_authority, $notice_id, $subcollec); } /* INSERT de la notice OK, on va traiter les auteurs 70# : personnal : type auteur 70 71# : collectivités : type auteur 71 1 seul en 700 idem pour les déclinaisons n en 701 n en 702 les 7#0 tombent en auteur principal : responsability_type = 0 les 7#1 tombent en autre auteur : responsability_type = 1 les 7#2 tombent en auteur secondaire : responsability_type = 2 */ $aut_array = array(); /* on compte tout de suite le nbre d'enreg dans les répétables */ $nb_repet_701 = sizeof($aut_701); $nb_repet_711 = sizeof($aut_711); $nb_repet_702 = sizeof($aut_702); $nb_repet_712 = sizeof($aut_712); //indicateur["710"]; /* renseignement de aut0 */ if ($aut_700[0][a] != "") { /* auteur principal en 700 ? */ $aut_array[] = array("entree" => $aut_700[0]['a'], "rejete" => $aut_700[0]['b'], "author_comment" => $aut_700[0]['c'] . " " . $aut_700[0]['d'], "date" => $aut_700[0]['f'], "type_auteur" => "70", "fonction" => $aut_700[0][4], "id" => 0, "responsabilite" => 0, "ordre" => 0, 'authority_number' => $aut_700[0][3]); } elseif ($aut_710[0]['a'] != "") { /* auteur principal en 710 ? */ if (substr($indicateur["710"][0], 0, 1) == "1") { $type_auteur = "72"; } else { $type_auteur = "71"; } $lieu = $aut_710[0]['e']; if (!$lieu) { $lieu = $aut_710[0]['k']; } $aut_array[] = array("entree" => $aut_710[0]['a'], "rejete" => $aut_710[0]['g'], "subdivision" => $aut_710[0]['b'], "author_comment" => $aut_710[0]['c'], "numero" => $aut_710[0]['d'], "lieu" => $lieu, "ville" => $aut_710[0]['l'], "pays" => $aut_710[0]['m'], "web" => $aut_710[0]['n'], "date" => $aut_710[0]['f'], "type_auteur" => $type_auteur, "fonction" => $aut_710[0][4], "id" => 0, "responsabilite" => 0, "ordre" => 0, 'authority_number' => $aut_710[0][3]); } /* renseignement de aut1 */ for ($i = 0; $i < $nb_repet_701; $i++) { $aut_array[] = array("entree" => $aut_701[$i]['a'], "rejete" => $aut_701[$i]['b'], "author_comment" => $aut_701[$i]['c'] . " " . $aut_701[$i]['d'], "date" => $aut_701[$i]['f'], "type_auteur" => "70", "fonction" => $aut_701[$i][4], "id" => 0, "responsabilite" => 1, "ordre" => $i + 1, 'authority_number' => $aut_701[$i][3]); } for ($i = 0; $i < $nb_repet_711; $i++) { if (substr($indicateur["711"][$i], 0, 1) == "1") { $type_auteur = "72"; } else { $type_auteur = "71"; } $lieu = $aut_711[$i]['e']; if (!$lieu) { $lieu = $aut_711[$i]['k']; } $aut_array[] = array("entree" => $aut_711[$i]['a'], "rejete" => $aut_711[$i]['g'], "subdivision" => $aut_711[$i]['b'], "author_comment" => $aut_711[$i]['c'], "numero" => $aut_711[$i]['d'], "lieu" => $lieu, "ville" => $aut_711[$i]['l'], "pays" => $aut_711[$i]['m'], "web" => $aut_711[$i]['n'], "date" => $aut_711[$i]['f'], "type_auteur" => $type_auteur, "fonction" => $aut_711[$i][4], "id" => 0, "responsabilite" => 1, "ordre" => $i + 1, 'authority_number' => $aut_711[$i][3]); } /* renseignement de aut2 */ for ($i = 0; $i < $nb_repet_702; $i++) { $aut_array[] = array("entree" => $aut_702[$i]['a'], "rejete" => $aut_702[$i]['b'], "author_comment" => $aut_702[$i]['c'] . " " . $aut_702[$i]['d'], "date" => $aut_702[$i]['f'], "type_auteur" => "70", "fonction" => $aut_702[$i][4], "id" => 0, "responsabilite" => 2, "ordre" => $i + 1, 'authority_number' => $aut_702[$i][3]); } for ($i = 0; $i < $nb_repet_712; $i++) { if (substr($indicateur["712"][$i], 0, 1) == "1") { $type_auteur = "72"; } else { $type_auteur = "71"; } $lieu = $aut_712[$i]['e']; if (!$lieu) { $lieu = $aut_712[$i]['k']; } $aut_array[] = array("entree" => $aut_712[$i]['a'], "rejete" => $aut_712[$i]['g'], "subdivision" => $aut_712[$i]['b'], "author_comment" => $aut_712[$i]['c'], "numero" => $aut_712[$i]['d'], "lieu" => $lieu, "ville" => $aut_712[$i]['l'], "pays" => $aut_712[$i]['m'], "web" => $aut_712[$i]['n'], "date" => $aut_712[$i]['f'], "type_auteur" => $type_auteur, "fonction" => $aut_712[$i][4], "id" => 0, "responsabilite" => 2, "ordre" => $i + 1, 'authority_number' => $aut_712[$i][3]); } // récup des infos auteurs et mise en tableau : // appel de la fonction membre d'importation et insertion en table $rqt_ins = "insert into responsability (responsability_author, responsability_notice, responsability_fonction, responsability_type, responsability_ordre) VALUES "; $values = ""; if (count($aut_array)) { for ($i = 0; $i < sizeof($aut_array); $i++) { $aut = array(); $aut['name'] = clean_string($aut_array[$i]['entree']); $aut['rejete'] = clean_string($aut_array[$i]['rejete']); $aut['type'] = $aut_array[$i]['type_auteur']; $aut['date'] = clean_string($aut_array[$i]['date']); $aut['subdivision'] = clean_string($aut_array[$i]['subdivision']); $aut['numero'] = clean_string($aut_array[$i]['numero']); $aut['lieu'] = clean_string($aut_array[$i]['lieu']); $aut['ville'] = clean_string($aut_array[$i]['ville']); $aut['pays'] = clean_string($aut_array[$i]['pays']); $aut['web'] = clean_string($aut_array[$i]['web']); $aut['author_comment'] = clean_string($aut_array[$i]['author_comment']); $aut['authority_number'] = clean_string($aut_array[$i]['authority_number']); //si on à demander la prise en compte des numéro d'autorités if ($authorities_notices && $aut['authority_number'] != "") { $aut_array[$i]["id"] = keep_authority_infos($aut['authority_number'], "author", $origin_authority, $notice_id, $aut); } if (!$aut_array[$i]["id"]) { $aut_array[$i]["id"] = auteur::import($aut); } $aut_array[$i]['fonction'] = trim($aut_array[$i]['fonction']); if ($aut_array[$i]["id"]) { if ($values != "") { $values .= ","; } $values .= " ('" . $aut_array[$i]["id"] . "','" . $notice_id . "','" . addslashes($aut_array[$i]['fonction']) . "','" . $aut_array[$i]['responsabilite'] . "','" . $aut_array[$i]['ordre'] . "') "; // $rqt = $rqt_ins . " ('".$aut_array[$i]["id"]."','".$notice_id."','".addslashes($aut_array[$i]['fonction'])."','".$aut_array[$i]['responsabilite']."','".$aut_array[$i]['ordre']."') " ; // @mysql_query($rqt, $dbh); } } @mysql_query($rqt_ins . $values); } // Titres uniformes global $pmb_use_uniform_title; if ($pmb_use_uniform_title) { $nb_tu = sizeof($tu_500); for ($i = 0; $i < $nb_tu; $i++) { $value_tu[$i]['name'] = $tu_500[$i]['a']; $value_tu[$i]['tonalite'] = $tu_500[$i]['u']; $value_tu[$i]['comment'] = $tu_500[$i]['n']; $value_tu[$i]['authority_number'] = $tu_500[$i]['3']; for ($j = 0; $j < count($tu_500_r[$i]); $j++) { $value_tu[$i]['distrib'][$j] = $tu_500_r[$i][$j]; } for ($j = 0; $j < count($tu_500_s[$i]); $j++) { $value_tu[$i]['ref'][$j] = $tu_500_s[$i][$j]; } for ($j = 0; $j < count($tu_500_j[$i]); $j++) { $value_tu[$i]['subdiv'][$j] = $tu_500_j[$i][$j]; } if ($authorities_notices && $aut['authority_number'] != "") { $tu_id = keep_authority_infos($value_tu[$i]['authority_number'], "uniform_title", $origin_authority, $notice_id, $value_tu[$i]); } else { $tu_id = titre_uniforme::import($value_tu[$i]); } if ($tu_id) { $requete = "INSERT INTO notices_titres_uniformes SET \n\t\t\t\t\tntu_num_notice='{$notice_id}', \n\t\t\t\t\tntu_num_tu='{$tu_id}', \n\t\t\t\t\tntu_titre='" . addslashes($tu_500[$i]['i']) . "', \n\t\t\t\t\tntu_date='" . addslashes($tu_500[$i]['k']) . "', \n\t\t\t\t\tntu_sous_vedette='" . addslashes($tu_500[$i]['l']) . "', \n\t\t\t\t\tntu_langue='" . addslashes($tu_500[$i]['m']) . "', \n\t\t\t\t\tntu_version='" . addslashes($tu_500[$i]['q']) . "', \n\t\t\t\t\tntu_mention='" . addslashes($tu_500[$i]['w']) . "',\n\t\t\t\t\tntu_ordre={$i} \t\t\t\t\n\t\t\t\t\t"; mysql_query($requete, $dbh); } } } global $lang_code; global $org_lang_code; $rqt_ins = "insert into notices_langues (num_notice, type_langue, code_langue, ordre_langue) VALUES "; $values = ""; for ($i = 0; $i < count($lang_code); $i++) { $lang_code[$i] = trim($lang_code[$i]); if ($values != "") { $values .= ","; } $values .= "('{$notice_id}',0, '" . addslashes($lang_code[$i]) . "','{$i}') "; //$rqt_ins = "insert into notices_langues (num_notice, type_langue, code_langue) VALUES ('$notice_id',0, '".addslashes($lang_code[$i])."') " ; //@mysql_query($rqt_ins, $dbh); } for ($i = 0; $i < count($org_lang_code); $i++) { $org_lang_code[$i] = trim($org_lang_code[$i]); if ($values != "") { $values .= ","; } $values .= "('{$notice_id}',1, '" . addslashes($org_lang_code[$i]) . "','" . $i . "') "; //$rqt_ins = "insert into notices_langues (num_notice, type_langue, code_langue) VALUES ('$notice_id',1, '".addslashes($org_lang_code[$i])."') " ; // @mysql_query($rqt_ins, $dbh); } @mysql_query($rqt_ins . $values, $dbh); //Import des catégories category_auto::save_info_categ(); //Calcule de la signature $sign = new notice_doublon(); $val = $sign->gen_signature($notice_id); mysql_query("update notices set signature='{$val}' where notice_id=" . $notice_id, $dbh); //Si on a un id de notice et qu'il n'est pas dans le tableau des notices créées, on l'ajoute if ($link_generate && trim($id_unimarc) !== "" && !$notices_crees[$id_unimarc]) { $notices_crees[$id_unimarc] = $notice_id; } elseif ($link_generate && trim($id_unimarc) !== "" && $notices_crees[$id_unimarc]) { //Si la notice a déjà été créé (Export des liens dans les notices liées) on remplace celle précédemment par celle en cour de traitement $niveau_biblio = $bibliographic_level . $hierarchic_level; switch ($niveau_biblio) { case 'm0': //On a une notice de monographie $notice_a_supp = $notices_crees[$id_unimarc]; //On garde les liens $requete = "UPDATE notices_relations SET num_notice='" . $notice_id . "' WHERE num_notice='" . $notice_a_supp . "' "; @mysql_query($requete, $dbh); $requete = "UPDATE notices_relations SET linked_notice='" . $notice_id . "' WHERE linked_notice='" . $notice_a_supp . "' "; @mysql_query($requete, $dbh); $ma_notice = new notice($notice_a_supp); $ma_notice->replace($notice_id); break; case 's1': //On a une notice de periodique $notice_a_supp = $notices_crees[$id_unimarc]; $ma_notice = new serial($notice_a_supp); $ma_notice->replace($notice_id); break; case 'b2': //On a une notice de bulletin $notice_a_supp = $notices_crees[$id_unimarc]; //Dans les bulletins $requete = "update bulletins set num_notice='" . $notice_id . "' where num_notice='" . $notice_a_supp . "' "; mysql_query($requete, $dbh); //Dans les relations entre notice $requete = "update notices_relations set num_notice='" . $notice_id . "' where num_notice='" . $notice_a_supp . "'"; mysql_query($requete, $dbh); $requete = "update notices_relations set linked_notice='" . $notice_id . "' where linked_notice='" . $notice_a_supp . "'"; mysql_query($requete, $dbh); notice::del_notice($notice_a_supp); break; case 'a2': //On a une notice d'article $notice_a_supp = $notices_crees[$id_unimarc]; //Dans les bulletins $requete = "update analysis set analysis_notice='" . $notice_id . "' where analysis_notice='" . $notice_a_supp . "' "; mysql_query($requete, $dbh); //Dans les relations entre notice $requete = "update notices_relations set num_notice='" . $notice_id . "' where num_notice='" . $notice_a_supp . "'"; mysql_query($requete, $dbh); $requete = "update notices_relations set linked_notice='" . $notice_id . "' where linked_notice='" . $notice_a_supp . "'"; mysql_query($requete, $dbh); notice::del_notice($notice_a_supp); break; } $notices_crees[$id_unimarc] = $notice_id; } }
$dateBulletin = ""; } else { $dateBulletin = pmb_mysql_result($queryAnnee, 0, 0); } if ($dateBulletin == '0000-00-00' || !isset($dateBulletin) || $dateBulletin == "") { $annee_tmp = ""; } else { $annee_tmp = substr($dateBulletin, 0, 4); } //On met à jour date de parution et année $reqMajBull = "UPDATE notices SET date_parution='" . $dateBulletin . "', year='" . $annee_tmp . "'\n\t\t\t\t\t\tWHERE notice_id='" . $mesNotices['notice_id'] . "'"; pmb_mysql_query($reqMajBull, $dbh); break; default: // Mise à jour du champ date_parution des notices (monographie et pério) $date_parution = notice::get_date_parution($mesNotices['year']); $reqMaj = "UPDATE notices SET date_parution='" . $date_parution . "' WHERE notice_id='" . $mesNotices['notice_id'] . "'"; pmb_mysql_query($reqMaj, $dbh); break; } } pmb_mysql_free_result($query); $next = $start + $lot; print "\n\t<form class='form-{$current_module}' name='current_state' action='./clean.php' method='post'>\n\t<input type='hidden' name='v_state' value=\"" . urlencode($v_state) . "\">\n\t<input type='hidden' name='spec' value=\"{$spec}\">\n\t<input type='hidden' name='start' value=\"{$next}\">\n\t<input type='hidden' name='count' value=\"{$count}\">\n\t</form>\n\t<script type=\"text/javascript\"><!-- \n\tsetTimeout(\"document.forms['current_state'].submit()\",1000); \n\t-->\n\t</script>"; } else { $spec = $spec - GEN_DATE_TRI; $not = pmb_mysql_query("SELECT count(1) FROM notices", $dbh); $compte = pmb_mysql_result($not, 0, 0); $v_state .= "<br /><img src=../../images/d.gif hspace=3>" . htmlentities($msg['gen_date_tri_msg'], ENT_QUOTES, $charset) . " : "; $v_state .= $compte . " " . htmlentities($msg['gen_date_tri_msg'], ENT_QUOTES, $charset); print "\n\t\t<form class='form-{$current_module}' name='process_state' action='./clean.php' method='post'>\n\t\t<input type='hidden' name='v_state' value=\"" . urlencode($v_state) . "\">\n\t\t<input type='hidden' name='spec' value=\"{$spec}\">\n\t\t</form>\n\t\t<script type=\"text/javascript\"><!--\n\t\t\tdocument.forms['process_state'].submit();\n\t\t\t-->\n\t\t</script>";