atualizaVersaoSistema.plsql
4.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*
**********************************************************************************
* *
* @package URBEM CNM - Soluções em Gestão Pública *
* @copyright (c) 2013 Confederação Nacional de Municípos *
* @author Confederação Nacional de Municípios *
* *
* O URBEM CNM é um software livre; você pode redistribuí-lo e/ou modificá-lo sob *
* os termos da Licença Pública Geral GNU conforme publicada pela Fundação do *
* Software Livre (FSF - Free Software Foundation); na versão 2 da Licença. *
* *
* Este programa é distribuído na expectativa de que seja útil, porém, *
* SEM NENHUMA GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU *
* ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral do GNU *
* para mais detalhes. *
* *
* Você deve ter recebido uma cópia da Licença Pública Geral do GNU "LICENCA.txt" *
* com este programa; se não, escreva para a Free Software Foundation Inc., *
* no endereço 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
* *
**********************************************************************************
*/
/*
* Script de função PLPGSQL
*
* URBEM Soluções de Gestão Pública Ltda
* www.urbem.cnm.org.br
*
* $Revision: 27926 $
* $Name$
* $Author: rodrigosoares $
* $Date: 2008-02-08 16:03:10 -0200 (Sex, 08 Fev 2008) $
*
* Casos de uso: uc-01.05.01
*/
/*
SELECT * from administracao.gestao order by cod_gestao;
SELECT * from administracao.historico_versao;
INSERT INTO administracao.historico_versao ( cod_gestao, versao, versao_db ) VALUES ( 1, '1.40.0', 1 ) ;
*/
--
-- Ticket #11326 - Realocar arquivos sql das Gestões Criação tabela historico_versao
--
--
-- Função de atualização de versao.
--
CREATE OR REPLACE FUNCTION administracao.fn_atualiza_historico_versao_sistema()
RETURNS TRIGGER AS $$
DECLARE
varVersao VARCHAR(30);
intVersaoDb INTEGER;
BEGIN
IF TG_OP='INSERT' THEN
SELECT gestao.versao, gestao.versao_db
INTO varVersao , intVersaoDb
FROM administracao.gestao
WHERE gestao.cod_gestao = new.cod_gestao;
UPDATE administracao.gestao SET versao = versao WHERE cod_gestao = new.cod_gestao;
ELSE
RAISE EXCEPTION 'atualização ou exclusão em "historico_versao" viola restrição de integridade referencial:.';
END IF;
RETURN NEW;
END;
$$ LANGUAGE plpgsql;
--
--
--
CREATE OR REPLACE FUNCTION administracao.fn_atualiza_versao_sistema()
RETURNS TRIGGER AS $$
DECLARE
varVersao VARCHAR(30);
intVersaoDb INTEGER;
BEGIN
SELECT historico_versao.versao, historico_versao.versao_db
INTO varVersao , intVersaoDb
FROM administracao.historico_versao
WHERE historico_versao.cod_gestao = new.cod_gestao
ORDER BY timestamp desc LIMIT 1;
IF FOUND THEN
new.versao := varVersao;
new.versao_db := intVersaoDb;
END IF;
Return NEW;
END;
$$ LANGUAGE plpgsql;
--
--
--
-- INSERT INTO administracao.historico_versao ( cod_gestao, versao, versao_db )
-- ( SELECT gestao.cod_gestao, gestao.versao, 0
-- FROM administracao.gestao order by cod_gestao) ;
--
--
--
--DROP TRIGGER fn_atualiza_historico_versao_sistema ON administracao.historico_versao;
CREATE TRIGGER fn_atualiza_historico_versao_sistema
AFTER INSERT OR UPDATE OR DELETE
ON administracao.historico_versao
FOR EACH ROW
EXECUTE PROCEDURE administracao.fn_atualiza_historico_versao_sistema()
;
--
--
--
DROP TRIGGER fn_atualiza_versao_sistema ON administracao.gestao;
CREATE TRIGGER fn_atualiza_versao_sistema
BEFORE UPDATE
ON administracao.gestao
FOR EACH ROW
EXECUTE PROCEDURE administracao.fn_atualiza_versao_sistema()
;