IT用語: データベーストランザクションとは|ACID特性で保証するデータ整合性
DBの一連の操作をまとめて原子的に扱うトランザクションのACID特性(原子性・一貫性・独立性・持続性)を解説。
データベーストランザクションとは
トランザクションは、「銀行口座Aから1万円を引き出し、口座Bに入金する」のような、論理的に1つのまとまりとして扱うべき複数のDB操作を指します。途中でエラーが発生した場合、一連の操作をすべて取り消し(ロールバック)、すべて成功した場合のみ確定(コミット)します。
ACID特性
| 特性 | 意味 |
|---|---|
| Atomicity(原子性) | すべて成功するか、すべて取り消すかのどちらか |
| Consistency(一貫性) | 制約・ルールを満たす整合した状態が維持される |
| Isolation(独立性) | 並行トランザクション同士が互いに影響しない |
| Durability(持続性) | コミットされたデータは障害後も失われない |
分離レベル
Isolation(独立性)の強さは4段階あります。強いほど整合性が高く、弱いほどパフォーマンスが高い。
| 分離レベル | ダーティリード | ファジーリード | ファントムリード |
|---|---|---|---|
| READ UNCOMMITTED | あり | あり | あり |
| READ COMMITTED | なし | あり | あり |
| REPEATABLE READ | なし | なし | あり |
| SERIALIZABLE | なし | なし | なし |
デッドロック
2つのトランザクションが互いに相手のロック解放を待ち続ける状態。DBMSが自動検出し、一方を強制ロールバックします。アプリ側では同じ順序でテーブルをロックする設計が予防策になります。
関連する用語 (データベース)
全23件を見るIT用語: MongoDBとは|JSONライクなドキュメント型NoSQLデータベース
スキーマレスなJSONドキュメントを格納するMongoDBの仕組み・集計パイプライン・RDBとの使い分けを解説。
データベースマイグレーション
データベースのスキーマ(テーブル構造)変更をバージョン管理し、順序立てて適用する仕組み。Prisma Migrate・Flyway・Liquibaseが代表的なツール。
IT用語: データベースインデックスとは|検索を高速化するB-Tree構造の仕組み
フルテーブルスキャンを避けてクエリを高速化するDBインデックスの仕組み・種類・設計の注意点を解説。
MySQL(マイSQL)
オープンソースのリレーショナルデータベース管理システム。WordPressをはじめ多くのWebアプリに採用され、読み取りパフォーマンスが高く導入が容易なRDBMSの定番。
IT用語: ORM(オブジェクトリレーショナルマッパー)とは|SQLを書かずにDBを操作
プログラミング言語のオブジェクトとDBのテーブルを対応付けるORMの仕組みとN+1問題を解説。
IT用語: Redisとは|高速インメモリデータストアの仕組みと活用パターン
メモリ上にデータを保存し高速なキャッシュ・セッション管理・Pub/Subを実現するRedisの仕組みと主要データ型を解説。