ALTER TABLE without locking the table?

Posted by Daniel on Stack Overflow See other posts from Stack Overflow or by Daniel
Published on 2009-01-21T00:22:42Z Indexed on 2010/05/16 2:30 UTC
Read the original article Hit count: 376

Filed under:
|
|
|

When doing an ALTER TABLE statement in MySQL, the whole table is read-locked for the duration of the statement. If it's a big table, that means insert or update statements could be locked for a looooong time. Is there a way to do a "hot alter", like adding a column in such a way that the table is still updatable throughout the process?

Mostly I'm interested in a solution for MySQL but I'd be interested in other RDBMS if MySQL can't do it.

To clarify, my purpose is simply to avoid downtime when a new feature that requires an extra table column is pushed to production. Any database schema will change over time, that's just a fact of life. I don't see why we should accept that these changes must inevitably result in downtime; that's just weak.

© Stack Overflow or respective owner

Related posts about sql

Related posts about mysql