sql >> Base de Datos >  >> RDS >> Mysql

Uso de bulk_update_mappings en SQLAlchemy para actualizar varias filas con diferentes valores

El enfoque es correcto en términos de uso. Lo único que cambiaría es algo como a continuación

mappings = []
i = 0

for b, foo_x in session.query(Bar, Foo.x).join(Foo, Foo.id==Bar.foo_id):
    info = {'id':b.id, 'x': foo_x}
    mappings.append(info)
    i = i + 1
    if i % 10000 == 0:
        session.bulk_update_mappings(Bar, mappings)
        session.flush()
        session.commit()
        mappings[:] = []

session.bulk_update_mappings(Bar, mappings)

Esto asegurará que no tenga demasiados datos colgando en la memoria y que no haga una inserción demasiado grande en la base de datos a la vez