Subversion Repositories eFlore/Projets.eflore-projets

Rev

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

Rev 780 Rev 816
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