MySQL 表空间往往会因为大量删除而增加。
我目前正在做的事情:
s = session.query(model)
s.delete()
我明白我可以添加
s.limit(1000)
每次删除后和sleep
并重新查询s.all()
以确定是否所有条目都已被删除。有没有办法只说批量1000
删除,直到所有原始记录都被清除?
最佳答案
如果您在单个事务中删除大量记录,您的事务日志和所需空间将会很大。如果您需要事务,这是不可避免的(重构为不需要它)。否则,在较小的记录 block (例如 100,000 条左右)之间调用 .commit()。
关于python - 少量删除 SQLAlchemy MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32915918/