繁体   English   中英

MYSQL 临时表 - 如何查看活动表

[英]MYSQL Temporary Tables - How to view active ones

我们公司有一个简单的“类CRM”软件。 有一些复杂的查询需要一些时间,日常使用的查询......所以我正在测试一些修改以使用临时表来替换我们需要的所有复杂连接和子查询。

到目前为止进展非常顺利,速度达到了 90% 以上。

由于它是一个 web 应用程序(codeigniter + mysql),我计划将它放在“生产测试”环境中,以便 50% 的用户可以帮助我测试它。 我想监视活动的表,如果可能的话,监视每个连接。

我的问题是 - 有什么方法可以查看在 mysql 实例中处于活动状态的所有临时表? 也许查看它的数据?

我读过一些关于插件或类似的东西,但这篇文章太混乱了,我无法理解。

非常感谢,对不起我的英语——不是我的母语。

temp table = 临时表,在查询后立即删除

没有直接的解决方案,除了记录所有查询并逐一执行以检查哪个查询需要 tmp_table

Created_tmp_tables这样的系统变量可能会给出一些想法

mysql> show status like '%tmp%';
+-------------------------+-------+
| Variable_name           | Value |
+-------------------------+-------+
| Created_tmp_disk_tables | 0     |
| Created_tmp_files       | 0     |
| Created_tmp_tables      | 0     |
+-------------------------+-------+

临时表的问题之一实际上是跟踪使用情况,然后是创建、索引和删除它们的开销——特别是对于 web 应用程序,其中临时表的生命周期通常与 HTTP 请求的生命周期一样长。

如果预编译的结果(即物化视图)会有所帮助,我设置了一个常规表,添加了引用 MySQL 连接 ID / web Z21D6F40CFB511982E4424E0E250A9 生成的源查询 + ID 时间的字段。数据以及是否会共享。

除了详细跟踪表的使用情况外,它还可以更轻松地解决查询调优问题,当然,架构也有更好的文档记录。

从 v5.7 开始的 MySQL INNODB 提供了一些关于来自INFORMATION_SCHEMA.INNODB_TEMP_TABLE_INF的临时表的信息,但它只显示了服务信息,没有关于表结构或名称的详细信息

mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_TEMP_TABLE_INFO;
+----------+--------------+--------+------------+
| TABLE_ID | NAME         | N_COLS | SPACE      |
+----------+--------------+--------+------------+
|     1066 | #sql569_1c_4 |      4 | 4243767290 |
+----------+--------------+--------+------------+
1 row in set (0.00 sec)

mysql> 

当您的数据集变得更大时,临时表将无济于事。 最后,他们如何提供帮助? 计算结果后必须将数据复制到这些表中,为什么不使用 memcached 缓存结果呢?

此外,我还看到了有些大的数据库(数十 GB)并且在单台机器上运行,并且查询运行得很快。 有一个问题是您是否正确配置了数据库服务器(软件和硬件)。 您可能会遇到暂时的加速,但不能保证它会永久有效。 我会优化运行应用程序所需的应用程序、查询、软件和硬件,然后我会使用 memcache 缓存结果,除非您需要查询结果的最新热拷贝。

我认为在视图临时表中没有意义,因为它们在连接期间存在并在关闭连接后死亡。 但是关于临时表有一个重要的事实。 因此,如果您在脚本中使用持久连接,则临时表将在此连接的生命周期内存在,并且使用此连接的客户端将可以访问相同的临时表。 同样在这种情况下,临时表将消耗系统资源。 为了避免这种情况,您应该在运行使用此临时表的必要查询后手动删除临时表。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM