¡@

Home 

OpenStack Study: 031_remove_duplicated_locations.py

OpenStack Index

**** CubicPower OpenStack Study ****

def upgrade(migrate_engine):

    meta = sqlalchemy.schema.MetaData(migrate_engine)

    image_locations = Table('image_locations', meta, autoload=True)

    if migrate_engine.name == "ibm_db_sa":

        il = orm.aliased(image_locations)

        # NOTE(wenchma): Get all duplicated rows.

        qry = (sql.select([il.c.id])

               .where(il.c.id > (sql.select([func.min(image_locations.c.id)])

                      .where(image_locations.c.image_id == il.c.image_id)

                      .where(image_locations.c.value == il.c.value)

                      .where(image_locations.c.meta_data == il.c.meta_data)

                      .where(image_locations.c.deleted == False)))

               .where(il.c.deleted == False)

               .execute()

               )

        for row in qry:

            stmt = (image_locations.delete()

                    .where(image_locations.c.id == row[0])

                    .where(image_locations.c.deleted == False))

            stmt.execute()

    else:

        session = orm.sessionmaker(bind=migrate_engine)()

        # NOTE(flaper87): Lets group by

        # image_id, location and metadata.

        grp = [image_locations.c.image_id,

               image_locations.c.value,

               image_locations.c.meta_data]

        # NOTE(flaper87): Get all duplicated rows

        qry = (session.query(*grp)

                      .filter(image_locations.c.deleted == False)

                      .group_by(*grp)

                      .having(func.count() > 1))

        for row in qry:

            # NOTE(flaper87): Not the fastest way to do it.

            # This is the best way to do it since sqlalchemy

            # has a bug around delete + limit.

            s = (sql.select([image_locations.c.id])

                 .where(image_locations.c.image_id == row[0])

                 .where(image_locations.c.value == row[1])

                 .where(image_locations.c.meta_data == row[2])

                 .where(image_locations.c.deleted == False)

                 .limit(1).execute())

            stmt = (image_locations.delete()

                    .where(image_locations.c.id == s.first()[0]))

            stmt.execute()

        session.close()

**** CubicPower OpenStack Study ****

def downgrade(migrate_engine):

    # NOTE(flaper87): There's no downgrade

    # path for this.

    return