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用語: データベース正規化とは|データの重複をなくすテーブル設計の基本
第1〜第3正規形(1NF・2NF・3NF)を使いデータの冗長性を排除するデータベース正規化の手順を解説。
IT用語: Redisとは|高速インメモリデータストアの仕組みと活用パターン
メモリ上にデータを保存し高速なキャッシュ・セッション管理・Pub/Subを実現するRedisの仕組みと主要データ型を解説。
ACID特性(トランザクション4要件)
データベーストランザクションの信頼性を保証する4つの特性。原子性(Atomicity)・一貫性(Consistency)・独立性(Isolation)・永続性(Durability)の頭文字をとった概念。
データベースマイグレーション
データベースのスキーマ(テーブル構造)変更をバージョン管理し、順序立てて適用する仕組み。Prisma Migrate・Flyway・Liquibaseが代表的なツール。
IT用語: MongoDBとは|JSONライクなドキュメント型NoSQLデータベース
スキーマレスなJSONドキュメントを格納するMongoDBの仕組み・集計パイプライン・RDBとの使い分けを解説。
ORM(オブジェクト関係マッピング)
プログラミング言語のオブジェクトとデータベースのテーブルを対応付け、SQLを書かずにDBを操作できるようにするライブラリ。Prisma・TypeORM・Sequelize等が代表的。