DBMS 中的审计跟踪

dbms 中的审计跟踪

Introduction

审计跟踪,也被称为事务日志,是数据库管理系统(DBMS)中记录对数据库进行的所有更改的记录。它用于跟踪和监视数据库活动,识别和解决问题,并确保数据的完整性和安全性。在本文中,我们将探讨审计跟踪在DBMS中的目的和好处,以及它们的工作原理,并提供实际和SQL代码示例来说明它们的实施和使用。

什么是DBMS中的审计追踪?

审计追踪是所有数据库事务的按时间顺序记录,包括插入、更新和删除。它捕获修改数据的旧值和新值,以及元数据,如负责更改的用户或应用程序、更改的日期和时间以及更改的类型(例如,插入、更新、删除)。

审计追踪可以用于跟踪和监控数据库活动,识别和解决问题,以及确保数据的完整性和安全性。例如,如果用户意外从数据库中删除了重要数据,可以使用审计追踪来识别责任用户并恢复已删除的数据。同样,如果数据被损坏或以未经授权的方式修改,审计追踪可以帮助识别原因并采取纠正措施。

审计追踪的类型

在数据库管理系统(DBMS)中,审计追踪是对数据库所做更改的记录。有几种类型的审计追踪可用于跟踪DBMS中的更改。主要的三种审计追踪类型是内部、外部和IRS(美国国内税务机构)审计追踪。

内部审计追踪 − 这些审计追踪被组织机构用来跟踪对其自身数据库所做的更改。它们通常用于确保数据完整性,检测和纠正错误,并满足监管要求。

Example − A company might use an internal audit trail to track changes made to its financial records or customer database.

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)用于跟踪对税务记录的更改。它们用于确保税务信息的准确性和完整性,并检测和防止税务欺诈。

示例− 美国国税局可能使用国税局审计追踪更改个人税务记录的情况,例如收入或扣除项的更改。

其他重要的审计追踪类型及其示例如下所述。

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.

示例 – 在医疗数据库中,可以使用基于触发器的审计跟踪来追踪对患者记录的更改,例如药物清单或生命体征的更改。

万物追踪 万物追踪

AI 追踪任何你关心的信息

万物追踪 44 查看详情 万物追踪

基于版本的审计追踪 − 这些审计追踪使用版本控制来跟踪对数据库的更改。每当对数据库中的一行进行更改时,都会创建一个带有更新数据的新版本行。旧版本的行保留下来,允许您查看对行所做的更改历史。

示例 – 在项目管理数据库中,可以使用基于版本的审计跟踪来追踪项目任务的更改,例如截止日期或完成状态的更改。

影子表 – 这些表用于在主表中更新行时存储行的副本。影子表包含行的旧版本和新版本,使您可以查看对行所做更改的历史。

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_changesAFTER INSERT OR UPDATE OR DELETE ON employeesFOR EACH ROWBEGIN   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 中的审计跟踪的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/236380.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月3日 23:29:13
下一篇 2025年11月3日 23:32:02

相关推荐

  • MySQL ERROR 1045出现的原因及怎么解决

    在命令行输入mysql -u root –p,输入密码,或通过工具连接数据库时,经常出现下面的错误信息,相信该错误信息很多人在使用mysql时都遇到过。 ERROR 1045 (28000): Access denied for user ‘root’@’loca…

    2025年12月5日 数据库
    000
  • linux上安装docker容器和mysql镜像拉取的方法

    docker pull xxxx 拉取镜像 docker run -it xxxx /bin/bash 启动镜像 启动docker服务 docker ps 查询运行中的容器 docker ps -a 查询所有容器,包括未运行的 mysql容器启动:docker run -itd –nam…

    数据库 2025年12月5日
    000
  • ubuntu下mysql 8.0.28怎么安装配置

    修改密码改了挺长时间,记录下安装过程 安装ssh服务: sudo apt-get install openssh-server 启动ssh服务: service sshd start 安装mysql服务器端: sudo apt install -y mysql-server 安装mysql客户端: …

    2025年12月5日
    000
  • MySQL事件调度器如何使用_能实现哪些自动化任务?

    mysql事件调度器是内置的定时任务工具,用于自动化周期性操作。一、开启方法:用show variables查看event_scheduler状态,若为off则在配置文件添加event_scheduler=on或临时执行set global开启;二、创建语法:create event定义触发时间、频…

    2025年12月5日 数据库
    000
  • mysql临键锁如何使用

    1、默认情况下,innodb使用临键锁锁定记录。 select … for update 2、当查询索引包含唯一属性时,临键锁将被优化并降级为记录锁,即只锁定索引本身,而不是范围。 3、不同场景下的临键锁会退化。 实例 事务1 start transaction;select SLEEP(4);…

    数据库 2025年12月5日
    000
  • MySQL命令行中如何修改MySQL密码

    方法一: mysql admin -u 用户名 -p 旧密码 passw 新密码 ‘u’为 username 的简称,‘p’为原 password 简称。 方法二: 我们先登录 MySQL 数据库。之后输入: mysql>set password for root@localhost = pa…

    数据库 2025年12月5日
    000
  • MySQL8如何设置自动创建时间和自动更新时间

    业务场景: 1、在数据库表中的数据,要求记录每一条新增数据的创建时间,时间格式要求明确至:年月日:时分秒。 2、在数据库表中的数据,要求记录每一条更新数据的更新时间,时间格式要求明确至:年月日:时分秒。 功能实现: 1、为每张业务表添加create_time 和update_time 字段,且将字段…

    数据库 2025年12月5日
    000
  • mysql InnoDB的四种锁定范围是什么

    1、记录锁,锁定索引中的记录。 2、间隙锁。 要么锁定索引记录中间的值,要么锁定第一个索引记录前面的值,要么锁定最后一个索引记录后面的值。 3、临键锁,是索引记录上的记录锁和索引记录前的间隙锁的组合。 4、插入意向锁,在insert操作中添加记录id的锁。 实例 — id 列为主键列或唯一索引列U…

    数据库 2025年12月5日
    000
  • MySQL中FROM_DAYS函数怎么用

    FROM_DAYS(date) SELECT FROM_DAYS(367) -> 0001-01-02 返回西元0年至今多少天的DATE值 以上就是MySQL中FROM_DAYS函数怎么用的详细内容,更多请关注创想鸟其它相关文章!

    数据库 2025年12月5日
    000
  • rocks mysql数据库多实例数据库配置的示例分析

    mysql数据库默认路径修改 启动httpd服务 mkdir -p /run/httpdsystemctl start httpd.service 1.什么是多实例? 在linux系统中代表:多个进程+多个线程+多个预分配内存结构 一般用来测试环境中,测试主从,高可用等。 多实例配置方案:(多个数据…

    数据库 2025年12月5日
    000
  • Linux怎样查看mysql密码

    相信很多小伙伴都经历过忘记密码,如果在Linux下忘记MySQL密码该怎么办? Linux查看mysql密码具体方法。 查看默认密码 grep ‘temporary password’ /var/log/mysqld.log 或者 cat /var/log/mysqld.log | grep ‘te…

    数据库 2025年12月5日
    000
  • MySQL数据库的基本操作实例分析

    一、MySQL简介 1、数据库管理软件分类 主要分为关系型和非关系型。 可以简单的理解为,关系型数据库需要有表结构,非关系型数据库是key-value存储的,没有表结构。 关系型:如sqllite,db2,oracle,access,sql server,MySQL,注意:sql语句通用。 非关系型…

    数据库 2025年12月5日
    000
  • mysql内连接查询实例分析

    1、分为隐式内连接查询和显示内连接查询,通过是否包含inner join关键字进行区别。 2、主表和从表中的数据都是满足连接条件则能够查询出来,不满足连接条件则不会查询出来。 实例 — 2.1 隐式内连接方式select *from t_category c, t_product p WHERE …

    数据库 2025年12月5日
    000
  • MySQL中binlog/redolog/undolog区别是什么

    MySQL binlog/redolog/undolog 的区别? 想和大家聊聊 innodb 中的锁机制,那么不可避免的要涉及到 mysql 的日志系统,binlog、redo log、undo log 等,看到有小伙伴总结的这三个日志还不错,赶紧拿来和各位小伙伴分享。 日志是mysql数据库的重…

    2025年12月5日 数据库
    000
  • phpstudy安装后mysql无法启动如何解决

    原因分析 我去网上查找phpstudy和mysql冲突的问题, 哦原来是 这两个mysql都占用的是3306端口, 而系统原来的mysql会开机启动(就是这里,会让原来的mysql作为服务开机启动监听)。那么当你打开phpstudy的时候, 便会再启动一个mysql服务,这个时候因为是同一个端口的关…

    2025年12月5日
    000
  • MySQL与PHP中的内置函数怎么用

    MySQL 内置函数 mysql 内置函数可以帮助我们更方便的处理表中的数据, 简化操作. 数学函数: 函数 描述 ABS()取绝对值SQRT()取根号MOD()取模FLOOR()返回不大于的最大整数值CELLING()返回不小于的最小整数值ROUND()四舍五入SIN()取正弦COS()取余弦 字…

    2025年12月5日
    000
  • 怎么在MySQL中设置时间

    MySQL支持多种时间格式,其中包括DATE、TIME、DATETIME和TIMESTAMP。这四种格式都有其特定的用途。 DATE格式表示日期,格式为“YYYY-MM-DD”,其中“YYYY”表示年份,“MM”表示月份,“DD”表示日期。 TIME格式表示时间,格式为“HH:MM:SS”,其中“H…

    数据库 2025年12月5日
    000
  • mysql左外连接查询的语法是什么

    1、以join左表为主表,显示主表的所有数据,并根据条件查询连接右表的数据。如果满足条件,则显示;如果不满足,则显示为null。 2、可以理解为在内部连接的基础上,确保左表的所有数据都显示。 语法 select 字段 from a left [outer] join b on 条件 实例 使用左连接…

    数据库 2025年12月5日
    000
  • 基于springboot+bootstrap+mysql+redis怎么搭建完整的权限架构

           首先将已经封装好的bootstrap脚本引入到我们现有的工程,目录如下:        到此我们的bootstraop框架引入完成,那么基于bootstrap框架我们现在开始开发属于我们的第一个bootstrap页面登陆页,打开我们的templates文件在底下找到我们login.ht…

    2025年12月5日 数据库
    100
  • 如何用Docker搭建外部可以访问的mysql

    安装mysql 8.0 docker run -p 63306:3306 -e mysql_root_password=zhaooleemysql –name zhaooleemysqldb -d mysql:8.0 p 53306:3306 将docker容器的3306端口映射到宿主机的6330…

    2025年12月5日 数据库
    000

发表回复

登录后才能评论
关注微信