mysql init_connect 参数的其他用处

mysql 默认是autocommit=1 的,

我们线上都设置一般是init_connect=’set autocommit=0; set names gbk;’ 这样的。

init_connect 是可以动态在线调整的,这样就有了一些其他的用处。
经过测试init_connect 是用户登录到数据库上之后,在执行第一次查询之前执行 里面的内容的。
如果init_connect 的内容有语法错误,导致执行失败,会导致用户无法执行查询,从mysql 退出。

init_connect 对具有super 权限的用户是无效的。

我们可以用init_connect 来登记用户的信息,例如一个测试如下:
创建测试表:
mysql.sock@test> create table t1 ( cur_user varchar(100), n_user varchar(100),in_time timestamp default current_timestamp()) ;
Query OK, 0 rows affected (0.09 sec)

设定 init_connect :
mysql.sock@(none)> set global init_connect=’insert into test.t1 (cur_user,n_user) values (current_user(),user())’;
Query OK, 0 rows affected (0.00 sec)

普通用户登录:
[root@test740_9 ~]# mysql -u lsl -plsl test
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1101066
Server version: 5.1.41-log MySQL Community Server (GPL)

Type ‘help;’ or ‘\h’ for help. Type ‘\c’ to clear the current input statement.

查询用户信息:
mysql.sock@test> select * from t1;
+———-+—————+———————+
| cur_user | n_user | in_time |
+———-+—————+———————+
| lsl@% | lsl@localhost | 2011-03-29 10:50:58 |
+———-+—————+———————+
1 row in set (0.00 sec)

记录了用户的客户端信息,当然还可以记录更多的信息,例如database() 记录当前数据库等等。

本次测试是直接将记录日志表,建在测试用户下,

注意: 对于所有的普通级别的用户,必须全部都要对日志表具有读写权限, 否则将导致,没有权限的用户无法使用数据库。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值