RepositorioMicromedicaoPostgresHBM.java
12 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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
/*
* Copyright (C) 2007-2007 the GSAN - Sistema Integrado de Gestão de Serviços de Saneamento
*
* This file is part of GSAN, an integrated service management system for Sanitation
*
* GSAN is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License.
*
* GSAN is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*/
/*
* GSAN - Sistema Integrado de Gestão de Serviços de Saneamento
* Copyright (C) <2007>
* Adriano Britto Siqueira
* Alexandre Santos Cabral
* Ana Carolina Alves Breda
* Ana Maria Andrade Cavalcante
* Aryed Lins de Araújo
* Bruno Leonardo Rodrigues Barros
* Carlos Elmano Rodrigues Ferreira
* Cláudio de Andrade Lira
* Denys Guimarães Guenes Tavares
* Eduardo Breckenfeld da Rosa Borges
* Fabíola Gomes de Araújo
* Flávio Leonardo Cavalcanti Cordeiro
* Francisco do Nascimento Júnior
* Homero Sampaio Cavalcanti
* Ivan Sérgio da Silva Júnior
* José Edmar de Siqueira
* José Thiago Tenório Lopes
* Kássia Regina Silvestre de Albuquerque
* Leonardo Luiz Vieira da Silva
* Márcio Roberto Batista da Silva
* Maria de Fátima Sampaio Leite
* Micaela Maria Coelho de Araújo
* Nelson Mendonça de Carvalho
* Newton Morais e Silva
* Pedro Alexandre Santos da Silva Filho
* Rafael Corrêa Lima e Silva
* Rafael Francisco Pinto
* Rafael Koury Monteiro
* Rafael Palermo de Araújo
* Raphael Veras Rossiter
* Roberto Sobreira Barbalho
* Rodrigo Avellar Silveira
* Rômulo Aurélio de Melo Souza Filho
* Rosana Carvalho Barbosa
* Sávio Luiz de Andrade Cavalcante
* Tai Mu Shih
* Thiago Augusto Souza do Nascimento
* Tiago Moreno Rodrigues
* Vivianne Barbosa Sousa
* Yara Taciane de Souza
*
* Este programa é software livre; você pode redistribuí-lo e/ou
* modificá-lo sob os termos de Licença Pública Geral GNU, conforme
* publicada pela Free Software Foundation; versão 2 da
* Licença.
* Este programa é distribuído na expectativa de ser útil, mas SEM
* QUALQUER GARANTIA; sem mesmo a garantia implícita de
* COMERCIALIZAÇÃO ou de ADEQUAÇÃO A QUALQUER PROPÓSITO EM
* PARTICULAR. Consulte a Licença Pública Geral GNU para obter mais
* detalhes.
* Você deve ter recebido uma cópia da Licença Pública Geral GNU
* junto com este programa; se não, escreva para Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
* 02111-1307, USA.
*/
package gcom.micromedicao;
import java.util.Collection;
import gcom.util.ErroRepositorioException;
import gcom.util.HibernateUtil;
import org.hibernate.Hibernate;
import org.hibernate.HibernateException;
import org.hibernate.Session;
/**
* Classe criada para sobrescrever(override) os metodos no padrão da base de dados Postgres
*
* @author Arthur Carvalho
* @date 16/12/2010
*/
public class RepositorioMicromedicaoPostgresHBM extends RepositorioMicromedicaoHBM {
/**
*
* [UC0629] Consultar Arquivo Texto para Leitura
*
* [FS0011 - Verificar Leituras];
*
* @author Hugo Amorim
* @date 20/08/2010
*/
public Collection pesquisarSituacaoLeitura(Integer anoMes,Integer idGrupo,Integer idRota)
throws ErroRepositorioException {
Collection retorno = null;
Session session = HibernateUtil.getSession();
String consulta;
try {
consulta = "SELECT \n"
+" COALESCE(medidosEnviados.qt_medidos_enviados,0) as qt_medidos_enviados, \n"
+" COALESCE(medidosRecebidos.qt_medidos_recebidos,0) as qt_medidos_recebidos, \n"
+" ABS(COALESCE(medidosEnviados.qt_medidos_enviados,0) - COALESCE(medidosRecebidos.qt_medidos_recebidos,0)) as diferencaMedidos, \n"
+" COALESCE(naoMedidosEnviados.qt_nao_medidos_enviados,0) as qt_nao_medidos_enviados, \n"
+" COALESCE(naoMedidosRecebidos.qt_nao_medidos_recebidos,0) as qt_nao_medidos_recebidos, \n"
+" ABS(COALESCE(naoMedidosEnviados.qt_nao_medidos_enviados,0) - COALESCE(naoMedidosRecebidos.qt_nao_medidos_recebidos,0)) as diferencaNaoMedidos, \n"
+" COALESCE(medidosImpressos.qt_medidos_impressos,0) as qt_medidos_impressos, \n"
+" COALESCE(medidosNaoImpressos.qt_medidos_nao_impressos,0) as qt_medidos_nao_impressos, \n"
+" COALESCE(naoMedidosImpressos.qt_nao_medidos_impressos,0) as qt_nao_medidos_impressos, \n"
+" COALESCE(naoMedidosNaoImpressos.qt_nao_medidos_nao_impressos,0) as qt_nao_medidos_nao_impressos, \n"
+" atre.txre_dsmotivofinalizacao as motivoFinalizacao, \n"
+" COALESCE(anormalidades.qt_anormalidades,0) as qt_anormalidades \n"
+" from micromedicao.arquivo_texto_rot_empr atre \n"
+" inner join micromedicao.rota rt on (atre.rota_id = rt.rota_id) \n"
//qt_medidos_enviados
+" LEFT JOIN ( \n"
+" SELECT r.rota_id as rota,mre.mrem_ammovimento as anomes, count(distinct(i.imov_id)) as qt_medidos_enviados \n"
+" FROM micromedicao.movimento_roteiro_empr mre \n"
+" INNER JOIN cadastro.imovel i on i.imov_id = mre.imov_id \n"
+" INNER JOIN cadastro.quadra q on q.qdra_id = i.qdra_id \n"
+" INNER JOIN micromedicao.rota r on r.rota_id = q.rota_id \n"
+" LEFT JOIN atendimentopublico.ligacao_agua la on la.lagu_id = mre.imov_id \n"
+" WHERE (la.hidi_id is not null or i.hidi_id is not null) and mre.mrem_ammovimento = :anoMes and mre.rota_id = :idRota " +
" GROUP BY rota,anomes) medidosEnviados \n"
+" on (atre.rota_id = medidosEnviados.rota and atre.txre_amreferencia = medidosEnviados.anomes) \n"
//qt_medidos_recebidos
+" LEFT JOIN ( \n"
+" SELECT \n"
+" mov.rota_id as rota, \n"
+" mcpf_ammovimento as anomes, \n"
+" count(distinct(mov.imov_id)) as qt_medidos_recebidos \n"
+" FROM \n"
+" faturamento.mov_conta_prefaturada mov \n"
+" inner join cadastro.imovel imo on ( mov.imov_id = imo.imov_id ) \n"
+" left join atendimentopublico.ligacao_agua la on ( imo.imov_id = la.lagu_id ) \n"
+" where \n"
+" imo.hidi_id is not null or la.hidi_id is not null \n"
+" GROUP BY rota,anomes ) medidosRecebidos \n"
+" on (atre.rota_id = medidosRecebidos.rota and atre.txre_amreferencia = medidosRecebidos.anomes) \n"
//qt_nao_medidos_enviados
+" LEFT JOIN ( \n"
+" SELECT r.rota_id as rota,mre.mrem_ammovimento as anomes, count(distinct(i.imov_id)) as qt_nao_medidos_enviados \n"
+" FROM micromedicao.movimento_roteiro_empr mre \n"
+" INNER JOIN cadastro.imovel i on i.imov_id = mre.imov_id \n"
+" INNER JOIN cadastro.quadra q on q.qdra_id = i.qdra_id \n"
+" INNER JOIN micromedicao.rota r on r.rota_id = q.rota_id \n"
+" LEFT JOIN atendimentopublico.ligacao_agua la on la.lagu_id = mre.imov_id \n"
+" WHERE (la.hidi_id is null and i.hidi_id is null) and mre.mrem_ammovimento = :anoMes and mre.rota_id = :idRota "
+" GROUP BY rota,anomes) naoMedidosEnviados \n"
+" on (atre.rota_id = naoMedidosEnviados.rota and atre.txre_amreferencia = naoMedidosEnviados.anomes) \n"
//qt_nao_medidos_recebidos
+" LEFT JOIN ( \n"
+" SELECT mcp.rota_id as rota, mcp.mcpf_ammovimento as anomes, count(distinct(mcp.imov_id)) as qt_nao_medidos_recebidos \n"
+" FROM faturamento.mov_conta_prefaturada mcp \n"
+" INNER JOIN cadastro.imovel i on i.imov_id = mcp.imov_id \n"
+" LEFT JOIN atendimentopublico.ligacao_agua la on la.lagu_id = mcp.imov_id \n"
+" WHERE (la.hidi_id is null and i.hidi_id is null) \n"
+" group by rota,anomes) naoMedidosRecebidos \n"
+" on (atre.rota_id = naoMedidosRecebidos.rota and atre.txre_amreferencia = naoMedidosRecebidos.anomes) \n"
//qt_medidos_impressos
+" LEFT JOIN( \n"
+" SELECT rota_id as rota, mcp.mcpf_ammovimento as anomes, count(distinct(mcp.imov_id)) as qt_medidos_impressos \n"
+" FROM faturamento.mov_conta_prefaturada mcp \n"
+" INNER JOIN cadastro.imovel imo on imo.imov_id = mcp.imov_id \n"
+" left join atendimentopublico.ligacao_agua la on ( imo.imov_id = la.lagu_id ) \n"
+" where \n"
+" ( imo.hidi_id is not null or la.hidi_id is not null ) and \n"
+" mcp.mcpf_icemissaoconta = 1 \n"
+" group by rota,anomes) medidosImpressos on (atre.rota_id = medidosImpressos.rota and atre.txre_amreferencia = medidosImpressos.anomes) \n"
// qt_medidos_nao_impressos
+" LEFT JOIN( \n"
+" SELECT rota_id as rota, mcp.mcpf_ammovimento as anomes, count(distinct(mcp.imov_id)) as qt_medidos_nao_impressos \n"
+" FROM faturamento.mov_conta_prefaturada mcp \n"
+" INNER JOIN cadastro.imovel imo on imo.imov_id = mcp.imov_id \n"
+" left join atendimentopublico.ligacao_agua la on ( imo.imov_id = la.lagu_id ) \n"
+" where \n"
+" ( imo.hidi_id is not null or la.hidi_id is not null ) and \n"
+" mcp.mcpf_icemissaoconta = 2 \n"
+" group by rota,anomes) medidosNaoImpressos on (atre.rota_id = medidosNaoImpressos.rota and atre.txre_amreferencia = medidosNaoImpressos.anomes) \n"
//qt_nao_medidos_impressos
+" LEFT JOIN( \n"
+" SELECT rota_id as rota, mcp.mcpf_ammovimento as anomes, count(distinct(mcp.imov_id)) as qt_nao_medidos_impressos \n"
+" FROM faturamento.mov_conta_prefaturada mcp \n"
+" INNER JOIN cadastro.imovel i on i.imov_id = mcp.imov_id \n"
+" LEFT JOIN atendimentopublico.ligacao_agua la on la.lagu_id = mcp.imov_id \n"
+" WHERE (la.hidi_id is null and i.hidi_id is null) and \n"
+" mcp.mcpf_icemissaoconta = 1 and (mcpf_nnleiturahidrometro is null or mcp.ltan_id is null) \n"
+" group by rota,anomes) naoMedidosImpressos on (atre.rota_id = naoMedidosImpressos.rota and atre.txre_amreferencia = naoMedidosImpressos.anomes) \n"
//qt_nao_medidos_nao_impressos
+" LEFT JOIN( \n"
+" SELECT rota_id as rota, mcp.mcpf_ammovimento as anomes, count(distinct(mcp.imov_id)) as qt_nao_medidos_nao_impressos \n"
+" FROM faturamento.mov_conta_prefaturada mcp \n"
+" INNER JOIN cadastro.imovel i on i.imov_id = mcp.imov_id \n"
+" LEFT JOIN atendimentopublico.ligacao_agua la on la.lagu_id = mcp.imov_id \n"
+" WHERE (la.hidi_id is null and i.hidi_id is null) and \n"
+" mcp.mcpf_icemissaoconta = 2 and (mcpf_nnleiturahidrometro is null or mcp.ltan_id is null) \n"
+" group by rota,anomes) naoMedidosNaoImpressos on (atre.rota_id = naoMedidosNaoImpressos.rota and atre.txre_amreferencia = naoMedidosNaoImpressos.anomes) \n"
// qt_anormalidades
+" LEFT JOIN( \n"
+" SELECT rota_id as rota, mcp.mcpf_ammovimento as anomes, count(distinct(imov_id)) as qt_anormalidades \n"
+" FROM faturamento.mov_conta_prefaturada mcp where \n"
+" csan_id is not null \n"
+" group by rota,anomes) anormalidades on (anormalidades.rota = medidosNaoImpressos.rota and anormalidades.anomes = medidosNaoImpressos.anomes) \n"
+" WHERE txre_amreferencia = :anoMes and rt.rota_id = :idRota ";
retorno = session.createSQLQuery(consulta)
.addScalar("qt_medidos_enviados", Hibernate.INTEGER)
.addScalar("qt_medidos_recebidos", Hibernate.INTEGER)
.addScalar("diferencaMedidos", Hibernate.INTEGER)
.addScalar("qt_nao_medidos_enviados", Hibernate.INTEGER)
.addScalar("qt_nao_medidos_recebidos", Hibernate.INTEGER)
.addScalar("diferencaNaoMedidos", Hibernate.INTEGER)
.addScalar("qt_medidos_impressos", Hibernate.INTEGER)
.addScalar("qt_medidos_nao_impressos", Hibernate.INTEGER)
.addScalar("qt_nao_medidos_impressos", Hibernate.INTEGER)
.addScalar("qt_nao_medidos_nao_impressos", Hibernate.INTEGER)
.addScalar("motivoFinalizacao", Hibernate.STRING)
.addScalar("qt_anormalidades", Hibernate.INTEGER)
.setInteger("anoMes", anoMes)
.setInteger("idRota", idRota)
.list();
} catch (HibernateException e) {
// levanta a exceção para a próxima camada
throw new ErroRepositorioException(e, "Erro no Hibernate");
} finally {
// fecha a sessão
HibernateUtil.closeSession(session);
}
return retorno;
}
}