Mysql
 sql >> Database >  >> RDS >> Mysql

Utilizzo di bulk_update_mappings in SQLAlchemy per aggiornare più righe con valori diversi

L'approccio è corretto in termini di utilizzo. L'unica cosa che cambierei è qualcosa come sotto

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)

Ciò ti assicurerà di non avere troppi dati in sospeso in memoria e di non eseguire un inserimento troppo grande nel DB in una sola volta