From 66d598520357f4f551adadd8cbba9a6a11f844bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jo=C3=A3o=20Pedro=20Sconetto?= Date: Tue, 14 Nov 2017 14:56:47 -0200 Subject: [PATCH] =?UTF-8?q?Corrige=20alguns=20erros=20de=20execu=C3=A7?= =?UTF-8?q?=C3=A3o?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sapl/legacy/migration.py | 30 ++++++++++++++++++++---------- 1 file changed, 20 insertions(+), 10 deletions(-) diff --git a/sapl/legacy/migration.py b/sapl/legacy/migration.py index 38647a460..f3f6be126 100644 --- a/sapl/legacy/migration.py +++ b/sapl/legacy/migration.py @@ -216,7 +216,7 @@ def migra_autor(): delete from autoria where cod_materia in ({}) and cod_autor in ({}); ''' - cursor = exec_legado('update autor set ind_excluido = null;') + #cursor = exec_legado('update autor set ind_excluido = null;') cursor = exec_legado(SQL_ENUMERA_REPETIDOS) autores_parlamentares = [r[0] for r in cursor if r[0]] @@ -226,26 +226,36 @@ def migra_autor(): sql = SQL_INFOS_AUTOR.format(cod_autor) cursor = exec_legado(sql) - autores = cursor.fetch_all() + autores = [] + + for response in cursor: + autores.append(response) + ids = [a[0] for a in autores] id_ativo, ids_inativos = ids[-1], ids[:-1] tabelas = ['autoria', 'documento_administrativo', 'proposicao', 'protocolo'] for tabela in tabelas: - # Para update e delete no MySQL -> SET SQL_SAFE_UPDATES = 0; - ids_inativos = str(ids_inativos).strip('[]') + if tabela == 'autoria': + # Para update e delete no MySQL -> SET SQL_SAFE_UPDATES = 0; + ids_inativos = str(ids_inativos).strip('[]') + + sql = SQL_ENUMERA_AUTORIA_REPETIDOS.format(str(ids).strip('[]')) + cursor = exec_legado(sql) - sql = SQL_ENUMERA_AUTORIA_REPETIDOS.format(str(ids).strip('[]')) - cursor = exec_legado(sql) + materias = [] + for response in cursor: + materias.append(response[0]) - for response in cursor: - if tabela == 'autoria': - sql = SQL_DELETE_AUTORIA.format(response[0], ids_inativos) + sql = SQL_DELETE_AUTORIA.format(str(materias).strip('[]'), ids_inativos) + import ipdb + ipdb.set_trace() + print('') sql = SQL_UPDATE_TABLES_AUTOR.format( tabela, id_ativo, ids_inativos) - exec_legado(sql) + #exec_legado(sql) def uniformiza_banco():