LoginSignup
4
1

More than 3 years have passed since last update.

【MySQL】テーブルロックが発生するか確認する方法

Posted at

tldl;

  • EXPLAIN SELECTしてtype=ALLならテーブルロックが発生します!

update

例えばこういうupdateSQLのときに

UPDATE users
SET field2    = CONCAT(field1, field2),
    field1     = NULL,
    updated_at = NOW()
WHERE field1 IS NOT NULL
  AND field1 != '';

EXPLAIN SELECTで実行してみてください

EXPLAIN SELECT * from users WHERE field1 IS NOT NULL
  AND field1 != '';

すると

image.png

typeがSELECTされるので、ALLになっていたらフルスキャン=テーブルロックが発生します!

Ref

4
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
1