SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

実例で学ぶASP.NET Webフォーム業務アプリケーション開発のポイント

データの同時更新を防ぐための排他制御

実例で学ぶASP.NET Webフォーム業務アプリケーション開発のポイント 第6回

  • X ポスト
  • このエントリーをはてなブックマークに追加

実行結果

 それでは実際に同時実行して結果を確認してみましょう。ブラウザで2つのウインドウ(またはタブ)で同一データの予約変更画面を開き、両方で更新を行ってみてください。

 うまくいけば、後から更新した方の画面は、次のようなメッセージが表示されるはずです。

図5 楽観的排他制御実行結果
図5 楽観的排他制御実行結果

まとめ

  • 排他制御とは複数ユーザーが同時に更新できないようにすること。
  • 排他制御は大きく2つに分けることができる。
    • 悲観的排他制御:トランザクションの開始から終了までデータをロックし、他のユーザーに触らせない。
    • 楽観的排他制御:更新前と更新時の対象データの状態を判定し、変更されていたら更新しない。
  • Webアプリケーションはステートレスのため、楽観的排他制御が主に用いられる。
  • 楽観的排他制御の実現方法として「時刻印アルゴリズム」が有名。
    • 「時刻印(タイムスタンプ)」をデータに持たせ、更新前後でタイムスタンプを比較することにより、変更されたかどうかを判定する。
  • EFで時刻印アルゴリズムを使用するには、POCO EntityでTimestamp属性を付けたプロパティを使う。
    • データベース上ではrowversion型の列として定義される。
    • EFが自動的にTimestamp属性のついた項目を使って楽観的排他制御を行う。
    • 排他エラーの発生は、DbUpdateConcurrencyExceptionで検出する。

 さて、次回はASP.NET Webフォーム業務アプリケーションにAjaxを導入する方法について解説する予定です。次回もお楽しみに。

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
実例で学ぶASP.NET Webフォーム業務アプリケーション開発のポイント連載記事一覧

もっと読む

この記事の著者

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

WINGSプロジェクト 高野 将(タカノ ショウ)

<個人紹介>新潟県長岡市在住の在宅リモートワークプログラマー。家事や育児、仕事の合間に長岡IT開発者勉強会(NDS)、Niigata.NET、TDDBCなどのコミュニティに関わったり、Web記事や書籍などの執筆を行ったりしている。著書に『アプリを作ろう! Visual C#入門 Visual C# 2017対応』(日経BP社、2017)など。<WINGSプロジェクトについて>有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS Twitter: @yyamada(公式)、@yyamada/wings(メンバーリスト) Facebook

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/6764 2012/09/25 14:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング