如何在mysql中如何追踪用户记录_MySql怎样追踪用户操作记录

本文介绍了如何在MySQL中利用init_connect变量和二进制日志追踪用户对数据库的操作记录,包括创建监控表、设置init_connect、分配用户权限,并通过实例展示了追踪删除操作的过程。
摘要由CSDN通过智能技术生成

有时,我们想追踪某个数据库操作记录,如想找出是谁操作了某个表(比如谁将字段名改了)。

二进制日志记录了操作记录,线程号等信息,但是却没有记录用户信息,因此需要结合init-connect来实现追踪。

init-connect,在每次连接的初始化阶段,记录下这个连接的用户,和connection_id信息。

实验步骤:

1:建监控连接信息的表

use dba;

create table accesslog(`thread_id` int primary key auto_increment, `time` timestamp, `localname` varchar(40), `machine_name` varchar(40));

2:设置变量init_connect

mysql> show variables like 'init%';

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| init_connect | |

| init_file | |

| init_slave | |

+---------------+-------+

3 rows in set (0.00 sec)

mysql> set global init_connect='insert into dba.accesslog(t

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值