mysql use db后很卡解决_MySQL
mysql use db后很卡解决
平时自己使用的一台mysql,use db之后,总是感觉很卡,按完回车要快1s才能返回。觉得有什么蹊跷,就打开了general log,发现简单的use test,mysql实际执行了很多内容:
Sql代码
130603 16:02:11 2 Query SELECT DATABASE()
2 Init DB test
2 Query show databases
2 Query show tables
2 Field List b
2 Field List bmw
2 Field List http_auth
2 Field List perf_machine
2 Field List t
2 Field List t1
2 Field List t2
2 Field List t5
2 Field List t_max_col
2 Field List tb
2 Field List tbcsv
2 Field List tbmemory
2 Field List tbmyisam
2 Field List tc
2 Field List total
2 Field List tt
而简单的show tables,show databases, select database(),show tables from test,实际都只对应一条generallog。
Sql代码
130603 16:17:12 2 Query show tables
130603 16:17:28 2 Query show databases
130603 16:17:48 2 Query SELECT DATABASE()
130603 16:19:44 3 Query show tables from test
从general log可以看到 一条use test,实际执行了多次dispatch_command(),使用gdb对general_log_write()设置断点,实际执行如下:
COM_QUERY,对应的sql是 SELECT DATABASE(),调用路径为:handle_one_connection(sql_connect.cc)->do_command(sql_parse.cc)->dispatch_command(sql_parse.cc,command=COM_QUERY,packet="SELECT DATABASE()");
COM_INIT_DB,调用路径为:handle_one_connection(sql_connect.cc)->do_command(sql_parse.cc)->dispatch_command(sql_parse.cc,command=COM_INIT_DB,packet="test");
COM_QUERY,对应的sql是 show databases,调用路径为:handle_one_connection(sql_connect.cc)->do_command(sql_parse.cc)->dispatch_command(sql_parse.cc,command=COM_QUERY,packet="show databases");
COM_QUERY,对应的sql是show tables,调用路径为:handle_one_connection(sql_connect.cc)->do_command(sql_parse.cc)->dispatch_command(sql_parse.cc,command=COM_QUERY,packet="show tables");
COM_FIELD_LIST,调用路径为:handle_one_connection(sql_connect.cc)->do_command(sql_parse.cc)->dispatch_command(sql_parse.cc,command=COM_FIELD_LIST,packet="columns_priv")。此处是n次调用(n为被use的schema下的表的个数,每次调用的时候,pachet内容即为表名);
因此在被use的schema下的表比较多的时候,自然会显得有些卡了(连续use同样的schema,则第二次use,则只会有COM_QUERY和COM_INIT_DB的过程), 为了避免use db后很卡,my.cnf里加上 no-auto-rehash;或者用mysql client连接的时候加上-A选项。
bitsCN.com
推荐阅读
-
Mysql升级到5.7后遇到的group by查询问题解决
-
如何LNMP一键包安装后解决MySQL无法远程连接问题?
-
wamp中mysql安装时能启动重启后无法启动的解决办法
-
解决mysql创建数据库后出现:Access denied for user 'root'@'%' to database 'xxx'的问题
-
win7系统安装2个mysql版本后连接不上数据库的问题如何解决?
-
将MySQL升级到8.0.x后的遇到到错误及解决
-
Asp.net Core 1.1 升级后操作mysql出错的解决办法
-
jsp插入mysql数据库后乱码的解决办法
-
mysql57重新安装后无法再次启动mysql57服务“本地计算机上的MySQL服务启动后停止。某些服务在未由其他服务或程序使用时将自动。”--解决方法
-
Django重装mysql后启动报错:No module named ‘MySQLdb’的解决方法