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 `tb_cel_test`.`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_test`.`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_test`.`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
|