Browse Source

Apaga registros migrados

pull/1496/head
Marcio Mazza 7 years ago
parent
commit
43784ffd50
  1. 25
      sapl/legacy/migration.py

25
sapl/legacy/migration.py

@ -395,6 +395,21 @@ def excluir_registrovotacao_duplicados():
assert 0 assert 0
def delete_old(legacy_model, cols_values):
def eq_clause(col, value):
if value is None:
return '{} IS NULL'.format(col)
else:
return '{}="{}"'.format(col, value)
delete_sql = 'delete from {} where {}'.format(
legacy_model._meta.db_table,
' and '.join([eq_clause(col, value)
for col, value in cols_values.items()]))
exec_sql(delete_sql, 'legacy')
class DataMigrator: class DataMigrator:
def __init__(self): def __init__(self):
@ -513,14 +528,22 @@ class DataMigrator:
with reversion.create_revision(): with reversion.create_revision():
new.save() new.save()
reversion.set_comment('Objeto criado pela migração') reversion.set_comment('Objeto criado pela migração')
# apaga registro do legado
delete_old(legacy_model, old.__dict__)
old_records = iter_sql_records( old_records = iter_sql_records(
'select * from ' + legacy_model._meta.db_table, 'legacy') 'select * from ' + legacy_model._meta.db_table, 'legacy')
else: else:
def save(new, old): def save(new, old):
with reversion.create_revision(): with reversion.create_revision():
save_with_id(new, getattr(old, legacy_pk_name)) pk_value = getattr(old, legacy_pk_name)
save_with_id(new, pk_value)
reversion.set_comment('Objeto criado pela migração') reversion.set_comment('Objeto criado pela migração')
# apaga registro do legado
delete_old(legacy_model, {legacy_pk_name: pk_value})
old_records = legacy_model.objects.all().order_by(legacy_pk_name) old_records = legacy_model.objects.all().order_by(legacy_pk_name)
ajuste_antes_salvar = AJUSTE_ANTES_SALVAR.get(model) ajuste_antes_salvar = AJUSTE_ANTES_SALVAR.get(model)

Loading…
Cancel
Save