タグ

ブックマーク / mita2db.hateblo.jp (1)

  • MySQL のロック範囲は実行計画で変わるという話 - mita2 database life

    最近、ANDPADでデータベース周りの技術顧問をさせて頂いています。ANDPADのエンジニアの皆さんから「データベースのロックまわりを詳しく知りたい!」というお話を受けて、先日、ロック周りの社内勉強会を開催しました。 SQLでは一般的なプログラミング言語と違って、ロックの制御を明示的に記述しません。ロックは暗黙的に(自動的に)データベースが必要なロックを獲得します。データベースのロックが わかりにくい・むずかしい と言われることが多いのはこういった背景があると思います。 MySQL のロック範囲は実行計画で変わる 更新対象の行がロックされるのは予測が付く方が多いと思います。 しかし、MySQL(InnoDB)では更新対象でなくても行がロックされることがあります。 このようなサンプルデータを使って説明します。 mysql> CREATE TABLE `lockt` ( -> `pk` big

    MySQL のロック範囲は実行計画で変わるという話 - mita2 database life
    halfrack
    halfrack 2020/08/20
    “FOR UPDATE SKIP LOCKED” 何その面白機能…
  • 1