代替のデータベース リビジョン追跡戦略: 監査証跡テーブル
前に説明した設計オプションに加えて、エンティティのリビジョンを管理するために専用の履歴テーブル (監査証跡) を使用することを検討してください。 この一元的なアプローチにより、すべてのデータベース変更の包括的な記録が提供されます。
監査証跡テーブルの構造
AuditTrail
テーブルには次のフィールドが含まれます:
<code>[ID] [int] IDENTITY(1,1) NOT NULL [UserID] [int] NULL [EventDate] [datetime] NOT NULL [TableName] [varchar](50) NOT NULL [RecordID] [varchar](20) NOT NULL [FieldName] [varchar](50) NULL [OldValue] [varchar](5000) NULL [NewValue] [varchar](5000) NULL</code>
テーブルの更新とトリガーの実装
各テーブルのトリガーは変更をキャプチャします。 すべての UPDATE
または INSERT
操作のトリガー:
LastUpdateByUserID
を記録します。AuditTrail
テーブルに記録します。メリットとデメリット
この方法にはいくつかの利点があります:
ただし、次の潜在的な欠点を考慮してください。
以上が専用の監査証跡テーブルはデータベースのリビジョン追跡をどのように改善できるのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。