DBMS 中的审计跟踪
本篇文章给大家分享《DBMS 中的审计跟踪》,覆盖了数据库的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
Introduction
审计跟踪,也被称为事务日志,是数据库管理系统(DBMS)中记录对数据库进行的所有更改的记录。它用于跟踪和监视数据库活动,识别和解决问题,并确保数据的完整性和安全性。在本文中,我们将探讨审计跟踪在DBMS中的目的和好处,以及它们的工作原理,并提供实际和SQL代码示例来说明它们的实施和使用。
什么是DBMS中的审计追踪?
审计追踪是所有数据库事务的按时间顺序记录,包括插入、更新和删除。它捕获修改数据的旧值和新值,以及元数据,如负责更改的用户或应用程序、更改的日期和时间以及更改的类型(例如,插入、更新、删除)。
审计追踪可以用于跟踪和监控数据库活动,识别和解决问题,以及确保数据的完整性和安全性。例如,如果用户意外从数据库中删除了重要数据,可以使用审计追踪来识别责任用户并恢复已删除的数据。同样,如果数据被损坏或以未经授权的方式修改,审计追踪可以帮助识别原因并采取纠正措施。
审计追踪的类型
在数据库管理系统(DBMS)中,审计追踪是对数据库所做更改的记录。有几种类型的审计追踪可用于跟踪DBMS中的更改。主要的三种审计追踪类型是内部、外部和IRS(美国国内税务机构)审计追踪。
内部审计追踪 − 这些审计追踪被组织机构用来跟踪对其自身数据库所做的更改。它们通常用于确保数据完整性,检测和纠正错误,并满足监管要求。
External audit trails − These audit trails are used by external organizations or auditors to review the data in a database. They are often used to verify the accuracy and reliability of the data for regulatory or compliance purposes.
IRS审计追踪 - 这些审计追踪由美国国税局(IRS)用于跟踪对税务记录的更改。它们用于确保税务信息的准确性和完整性,并检测和防止税务欺诈。
Example − A company might use an internal audit trail to track changes made to its financial records or customer database.
示例− 外部审计员可能会使用外部审计追踪来审查公司的财务记录,以确保符合会计准则。
示例− 美国国税局可能使用国税局审计追踪更改个人税务记录的情况,例如收入或扣除项的更改。
其他重要的审计追踪类型及其示例如下所述。
Log-based audit trails − These audit trails use a log file to record changes made to the database. The log file contains information about each change, such as the time the change was made, the user who made the change, and the type of change (e.g., insert, update, delete).
Trigger-based audit trails − These audit trails use triggers, which are special types of database objects that are activated when a specific event occurs (e.g., a row is inserted or updated). Triggers can be used to record changes made to the database in an audit table.
基于版本的审计追踪 − 这些审计追踪使用版本控制来跟踪对数据库的更改。每当对数据库中的一行进行更改时,都会创建一个带有更新数据的新版本行。旧版本的行保留下来,允许您查看对行所做的更改历史。
影子表 - 这些表用于在主表中更新行时存储行的副本。影子表包含行的旧版本和新版本,使您可以查看对行所做更改的历史。
示例 - 在财务数据库中,可以使用基于日志的审计跟踪来跟踪账户余额或交易的变化。
示例 - 在医疗数据库中,可以使用基于触发器的审计跟踪来追踪对患者记录的更改,例如药物清单或生命体征的更改。
示例 - 在项目管理数据库中,可以使用基于版本的审计跟踪来追踪项目任务的更改,例如截止日期或完成状态的更改。
Example − In a customer relationship management (CRM) database, a shadow table might be used to track changes to customer profiles, such as changes to contact information or purchasing history.
SQL示例
以下是使用SQL跟踪对名为"employees"的表所做更改的审计追踪示例 -
CREATE TABLE employees_audit ( employee_id INTEGER, action VARCHAR(255), change_time TIMESTAMP, old_data JSON, new_data JSON ); CREATE TRIGGER audit_employee_changes AFTER INSERT OR UPDATE OR DELETE ON employees FOR EACH ROW BEGIN IF (TG_OP = 'DELETE') THEN INSERT INTO employees_audit (employee_id, action, change_time, old_data) VALUES (OLD.id, 'DELETE', NOW(), OLD.*); ELSEIF (TG_OP = 'UPDATE') THEN INSERT INTO employees_audit (employee_id, action, change_time, old_data, new_data) VALUES (OLD.id, 'UPDATE', NOW(), OLD.*, NEW.*); ELSE INSERT INTO employees_audit (employee_id, action, change_time, new_data) VALUES (NEW.id, 'INSERT', NOW(), NEW.*); END IF; END;
这个SQL代码创建了一个名为"employees_audit"的审计表和一个名为"audit_employee_changes"的触发器。当在"employees"表中插入、更新或删除一行时,触发器将被激活。
When the trigger is activated, it inserts a new row into the "employees_audit" table with information about the change that was made. The "action" column specifies the type of change (INSERT, UPDATE, or DELETE), the "change_time" column records the time the change was made, and the "old_data" and "new_data" columns contain the data before and after the change, respectively.
For example, if a row is updated in the "employees" table, the trigger will insert a new row into the "employees_audit" table with the action "UPDATE", the current time, the old data from the row before the update, and the new data from the row after the update. This allows you to track changes made to the "employees" table over time.
数据库管理系统中审计跟踪的好处
There are several benefits to implementing an audit trail in a DBMS −
Data integrity and security − Audit trails help to ensure the integrity and security of data by tracking and monitoring all database activity. This can help to prevent unauthorized access, modification, or deletion of data, as well as detect and correct errors or corruption.
合规性 − 许多行业和组织对数据管理有严格的法规和合规要求,例如欧盟的个人数据保护通用数据保护条例(GDPR)或美国的医疗数据保险可移植性与责任法案(HIPAA)。审计追踪可以帮助组织满足这些要求,通过提供所有数据库活动的记录,并确保数据以安全和符合规定的方式处理。
故障排除和问题解决 − 审计跟踪可以用于识别和解决数据库的问题,如错误,损坏或未经授权的访问。它们还可以通过提供导致问题的更改记录来帮助解决问题,从而可以采取纠正措施。
审计和法证分析 − 审计轨迹可用于审计和法证分析,以调查潜在的安全漏洞或欺诈活动。它们提供了所有数据库活动的详细记录,可用于识别和跟踪可疑活动。
结论
总之,审计追踪是DBMS中对数据库所做更改的记录。它用于确保数据的完整性,检测和纠正错误,并满足监管要求。可以使用多种类型的审计追踪,包括基于日志、基于触发器、基于版本和影子表。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《DBMS 中的审计跟踪》文章吧,也可关注golang学习网公众号了解相关技术文章。

- 上一篇
- MySQL 中的查询统计

- 下一篇
- 数据库规范化的重要性
-
- 数据库 · MySQL | 48分钟前 | 解码 aes base64 FROM_BASE64 AES_DECRYPT
- MySQL中decode函数使用教程及详解
- 398浏览 收藏
-
- 数据库 · MySQL | 58分钟前 | 性能优化 复合主键 CREATETABLE 主键约束 ALTERTABLE
- MySQL主键约束及多种添加方法
- 349浏览 收藏
-
- 数据库 · MySQL | 2小时前 | 索引 数据类型 字符集 存储引擎 CREATETABLE
- MySQL新建表教程数据库建表实操指南
- 246浏览 收藏
-
- 数据库 · MySQL | 20小时前 | 备份 innodb 权限管理 字符集 CREATEDATABASE
- MySQL新建数据库详解及操作指南
- 447浏览 收藏
-
- 数据库 · MySQL | 23小时前 | 备份 innodb 权限管理 utf8mb4 CREATEDATABASE
- MySQL新建数据库操作指南与示例
- 119浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- AI Make Song
- AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
- 17次使用
-
- SongGenerator
- 探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
- 13次使用
-
- BeArt AI换脸
- 探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
- 13次使用
-
- 协启动
- SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
- 16次使用
-
- Brev AI
- 探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
- 18次使用
-
- MySQL主从切换的超详细步骤
- 2023-01-01 501浏览
-
- Mysql-普通索引的 change buffer
- 2023-01-25 501浏览
-
- MySQL高级进阶sql语句总结大全
- 2022-12-31 501浏览
-
- Mysql报错:message from server: * is blocked because of many
- 2023-02-24 501浏览
-
- 腾讯云大佬亲码“redis深度笔记”,不讲一句废话,全是精华
- 2023-02-22 501浏览