| Line 12... |
Line 12... |
| 12 |
delimiter |
|
12 |
delimiter |
|
| Line 13... |
Line 13... |
| 13 |
|
13 |
|
| 14 |
-- obtient le nombre de matches sur nom_sel = nom_sci
|
14 |
-- obtient le nombre de matches sur nom_sel = nom_sci
|
| 15 |
CREATE PROCEDURE getNomSciCount(IN _nom varchar(500), OUT param1 INT)
|
15 |
CREATE PROCEDURE getNomSciCount(IN _nom varchar(500), OUT param1 INT)
|
| 16 |
BEGIN
|
16 |
BEGIN
|
| 17 |
SELECT sum(c) INTO param1 FROM (SELECT count(1) as c FROM tb_eflore.bdtfx_v1_01 b WHERE nom_sci = _nom UNION ALL SELECT count(1) FROM tb_eflore.bdtxa_v1_00 a WHERE nom_sci = _nom) AS req;
|
17 |
SELECT sum(c) INTO param1 FROM (SELECT count(1) as c FROM `BASESOURCE`.`bdtfx_v1_01` b WHERE nom_sci = _nom UNION ALL SELECT count(1) FROM `BASESOURCE`.`bdtxa_v1_00` a WHERE nom_sci = _nom) AS req;
|
| 18 |
END
|
18 |
END
|
| 19 |
|
|
19 |
|
|
| 20 |
-- retourne les paramètres d'une match
|
20 |
-- retourne les paramètres d'une match
|
| 21 |
CREATE PROCEDURE getNomSci(IN _nom varchar(500), OUT param1 char(5), OUT param2 varchar(601), OUT param3 INT, OUT param4 INT, OUT param5 varchar(255))
|
21 |
CREATE PROCEDURE getNomSci(IN _nom varchar(500), OUT param1 char(5), OUT param2 varchar(601), OUT param3 INT, OUT param4 INT, OUT param5 varchar(255))
|
| 22 |
BEGIN
|
22 |
BEGIN
|
| 23 |
SELECT * INTO param1, param2, param3, param4, param5 FROM
|
23 |
SELECT * INTO param1, param2, param3, param4, param5 FROM
|
| 24 |
(SELECT "bdtfx", CONCAT(b.nom_sci, ' ', b.auteur), b.num_nom, b.num_taxonomique, b.famille FROM tb_eflore.bdtfx_v1_01 b WHERE nom_sci = _nom
|
24 |
(SELECT "bdtfx", CONCAT(b.nom_sci, ' ', b.auteur), b.num_nom, b.num_taxonomique, b.famille FROM `BASESOURCE`.`bdtfx_v1_01` b WHERE nom_sci = _nom
|
| 25 |
UNION ALL
|
25 |
UNION ALL
|
| 26 |
SELECT "bdtxa", CONCAT(a.nom_sci, ' ', a.auteur), a.num_nom, a.num_tax, a.famille FROM tb_eflore.bdtxa_v1_00 a WHERE nom_sci = _nom) AS req;
|
26 |
SELECT "bdtxa", CONCAT(a.nom_sci, ' ', a.auteur), a.num_nom, a.num_tax, a.famille FROM `BASESOURCE`.`bdtxa_v1_00` a WHERE nom_sci = _nom) AS req;
|
| 27 |
END
|
27 |
END
|
| Line 28... |
Line 28... |
| 28 |
|
|
28 |
|
|
| 29 |
|
29 |
|
| 30 |
-- obtient le nombre de matches sur nom_sel = CONCAT(nom_sci, " ", auteur)
|
30 |
-- obtient le nombre de matches sur nom_sel = CONCAT(nom_sci, " ", auteur)
|
| 31 |
-- quasiment identique à ci-dessus, sauf que nous excluons de la recherche de bdtfx et bdtxa les nom dont le nom d'auteur est ''
|
31 |
-- quasiment identique à ci-dessus, sauf que nous excluons de la recherche de bdtfx et bdtxa les nom dont le nom d'auteur est ''
|
| 32 |
CREATE PROCEDURE getNomSciAuteurCount(IN _nom varchar(500), OUT param1 INT)
|
32 |
CREATE PROCEDURE getNomSciAuteurCount(IN _nom varchar(500), OUT param1 INT)
|
| 33 |
BEGIN
|
33 |
BEGIN
|
| 34 |
SELECT sum(c) INTO param1 FROM (SELECT count(1) as c FROM tb_eflore.bdtfx_v1_01 b WHERE CONCAT(nom_sci, ' ', auteur) = _nom UNION ALL SELECT count(1) FROM tb_eflore.bdtxa_v1_00 a WHERE CONCAT(nom_sci, ' ', auteur) = _nom) AS req;
|
34 |
SELECT sum(c) INTO param1 FROM (SELECT count(1) as c FROM `BASESOURCE`.`bdtfx_v1_01` b WHERE CONCAT(nom_sci, ' ', auteur) = _nom UNION ALL SELECT count(1) FROM `BASESOURCE`.`bdtxa_v1_00` a WHERE CONCAT(nom_sci, ' ', auteur) = _nom) AS req;
|
| 35 |
END
|
35 |
END
|
| 36 |
|
|
36 |
|
|
| 37 |
-- retourne les paramètres d'une match
|
37 |
-- retourne les paramètres d'une match
|
| 38 |
CREATE PROCEDURE getNomSciAuteur(IN _nom varchar(500), OUT param1 char(5), OUT param2 varchar(601), OUT param3 INT, OUT param4 INT, OUT param5 varchar(255))
|
38 |
CREATE PROCEDURE getNomSciAuteur(IN _nom varchar(500), OUT param1 char(5), OUT param2 varchar(601), OUT param3 INT, OUT param4 INT, OUT param5 varchar(255))
|
| 39 |
BEGIN
|
39 |
BEGIN
|
| 40 |
SELECT * INTO param1, param2, param3, param4, param5 FROM
|
40 |
SELECT * INTO param1, param2, param3, param4, param5 FROM
|
| 41 |
(SELECT "bdtfx", CONCAT(b.nom_sci, ' ', b.auteur), b.num_nom, b.num_taxonomique, b.famille FROM tb_eflore.bdtfx_v1_01 b WHERE CONCAT(nom_sci, ' ', auteur) = _nom AND auteur != ''
|
41 |
(SELECT "bdtfx", CONCAT(b.nom_sci, ' ', b.auteur), b.num_nom, b.num_taxonomique, b.famille FROM `BASESOURCE`.`bdtfx_v1_01` b WHERE CONCAT(nom_sci, ' ', auteur) = _nom AND auteur != ''
|
| 42 |
UNION ALL
|
42 |
UNION ALL
|
| 43 |
SELECT "bdtxa", CONCAT(a.nom_sci, ' ', a.auteur), a.num_nom, a.num_tax, a.famille FROM tb_eflore.bdtxa_v1_00 a WHERE CONCAT(nom_sci, ' ', auteur) = _nom AND auteur != '') AS req;
|
43 |
SELECT "bdtxa", CONCAT(a.nom_sci, ' ', a.auteur), a.num_nom, a.num_tax, a.famille FROM `BASESOURCE`.`bdtxa_v1_00` a WHERE CONCAT(nom_sci, ' ', auteur) = _nom AND auteur != '') AS req;
|
| Line 44... |
Line 44... |
| 44 |
END
|
44 |
END
|
| 45 |
|
|
45 |
|
|
| Line 50... |
Line 50... |
| 50 |
DECLARE subst INT DEFAULT 0;
|
50 |
DECLARE subst INT DEFAULT 0;
|
| 51 |
DECLARE _id_observation bigint(20) DEFAULT 0;
|
51 |
DECLARE _id_observation bigint(20) DEFAULT 0;
|
| 52 |
DECLARE _nom varchar(255) DEFAULT NULL;
|
52 |
DECLARE _nom varchar(255) DEFAULT NULL;
|
| Line 53... |
Line 53... |
| 53 |
|
53 |
|
| 54 |
-- la requête principale de sélection des observations à mettre à jour
|
54 |
-- la requête principale de sélection des observations à mettre à jour
|
| 55 |
DECLARE cur1 CURSOR FOR SELECT id_observation, nom_sel FROM cel_obs WHERE nom_referentiel IS NULL AND nom_sel != '' AND nom_sel IS NOT NULL AND nom_ret_nn IS NULL; -- 78149
|
55 |
DECLARE cur1 CURSOR FOR SELECT id_observation, nom_sel FROM `BASEEDIT`.`cel_obs` WHERE nom_referentiel IS NULL AND nom_sel != '' AND nom_sel IS NOT NULL AND nom_ret_nn IS NULL; -- 78149
|
| 56 |
-- DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
|
56 |
-- DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
|
| Line 57... |
Line 57... |
| 57 |
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;
|
57 |
DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done = 1;
|
| Line 63... |
Line 63... |
| 63 |
CALL getNomSciCount(_nom, @a);
|
63 |
CALL getNomSciCount(_nom, @a);
|
| 64 |
-- SELECT _id_observation, _nom, @a;
|
64 |
-- SELECT _id_observation, _nom, @a;
|
| 65 |
IF @a = 1 THEN
|
65 |
IF @a = 1 THEN
|
| 66 |
CALL getNomSci(_nom, @_ref, @_nom, @_num_nom, @_num_tax, @_famille);
|
66 |
CALL getNomSci(_nom, @_ref, @_nom, @_num_nom, @_num_tax, @_famille);
|
| 67 |
SELECT "updb: getNomSci", _id_observation, _nom, '=', @_ref, @_nom, @_num_nom, @_num_tax, @_famille;
|
67 |
SELECT "updb: getNomSci", _id_observation, _nom, '=', @_ref, @_nom, @_num_nom, @_num_tax, @_famille;
|
| 68 |
UPDATE tb_cel.cel_obs c SET
|
68 |
UPDATE `BASEEDIT`.`cel_obs` c SET
|
| 69 |
c.nom_referentiel = @_ref,
|
69 |
c.nom_referentiel = @_ref,
|
| 70 |
c.nom_ret = @_nom,
|
70 |
c.nom_ret = @_nom,
|
| 71 |
c.nom_ret_nn = @_num_nom,
|
71 |
c.nom_ret_nn = @_num_nom,
|
| 72 |
c.nt = @_num_tax,
|
72 |
c.nt = @_num_tax,
|
| 73 |
c.famille = @_famille
|
73 |
c.famille = @_famille
|
| Line 76... |
Line 76... |
| 76 |
/* ELSE
|
76 |
/* ELSE
|
| 77 |
CALL getNomSciAuteurCount(_nom, @a);
|
77 |
CALL getNomSciAuteurCount(_nom, @a);
|
| 78 |
IF @a = 1 THEN
|
78 |
IF @a = 1 THEN
|
| 79 |
CALL getNomSciAuteur(_nom, @_ref, @_nom, @_num_nom, @_num_tax, @_famille);
|
79 |
CALL getNomSciAuteur(_nom, @_ref, @_nom, @_num_nom, @_num_tax, @_famille);
|
| 80 |
SELECT "updb: getNomSciAuteur", _id_observation, _nom, '=', @_ref, @_nom, @_num_nom, @_num_tax, @_famille;
|
80 |
SELECT "updb: getNomSciAuteur", _id_observation, _nom, '=', @_ref, @_nom, @_num_nom, @_num_tax, @_famille;
|
| 81 |
UPDATE tb_cel.cel_obs c SET
|
81 |
UPDATE `BASEEDIT`.`cel_obs` c SET
|
| 82 |
c.nom_referentiel = @_ref,
|
82 |
c.nom_referentiel = @_ref,
|
| 83 |
c.nom_ret = @_nom,
|
83 |
c.nom_ret = @_nom,
|
| 84 |
c.nom_ret_nn = @_num_nom,
|
84 |
c.nom_ret_nn = @_num_nom,
|
| 85 |
c.nt = @_num_tax,
|
85 |
c.nt = @_num_tax,
|
| 86 |
c.famille = @_famille
|
86 |
c.famille = @_famille
|