Hãy xem xét một bảng tạm thời sẽ là bản sao chính xác của bảng cuối cùng của bạn, được làm sạch sau mỗi lần chạy:
engine = create_engine('postgresql+psycopg2://user:[email protected]')
df.to_sql('temp_table', engine, if_exists='replace')
sql = """
UPDATE final_table AS f
SET col1 = t.col1
FROM temp_table AS t
WHERE f.id = t.id
"""
with engine.begin() as conn: # TRANSACTION
conn.execute(sql)