1

我有一堆 MySQL 查询,它们使用临时表将复杂/昂贵的查询分成小块。

create temporary table product_stats (
     product_id int 
    ,count_vendors int 
    ,count_categories int
    ,...
);

-- Populate initial values.
insert into product_stats(product_id) select product_id from product;

-- Incrementally collect stats info.
update product_stats ... join vendor ... set count_vendors = count(vendor_id);
update product_stats ... join category... set count_categories = count(category_id);
....

-- Consume the resulting temporary table.
select * from product_stats;

问题是,当我使用连接池时,即使关闭java.sql.Connection.

在执行所需的查询之前,我可以手动删除它们(drop temporary table x;),但这可能会因错误而发生。

有没有办法(JDBC/MySQL、API/配置)在不关闭数据库连接的情况下重置当前会话中创建的所有临时表(如您所知,我不是指java.sql.Connection.close()),这样我仍然可以使用优势提供连接池?

编辑:

似乎只有从 MySQL 5.7.3 版开始,他们才开始实施“重置连接”功能。(发布说明:https ://dev.mysql.com/doc/relnotes/mysql/5.7/en/news-5-7-3.html )但是,我暂时不会使用它,因为 5.7 版仍在运行开发版本。

4

1 回答 1

0

问:有没有办法(JDBC/MySQL,API/配置)在不关闭数据库连接的情况下重置当前会话中创建的所有临时表。

答:不。没有可用的“重置”。您可以在会话中发出DROP TEMPORARY TABLE foo语句,但您必须提供要删除的临时表的名称。

规范模式是让创建临时表的进程在连接返回池之前删除它。(我通常在块中处理这个finally。)

如果我们期望其他进程可能会在会话中留下临时表(并且为了防御,这就是我们所期望的),我们通常会DROP TEMPORARY TABLE IF EXISTS foo在尝试创建临时表之前执行 a。

编辑

上面的答案对于 MySQL 到 5.6 版是正确的。

@mr.Kame (OP) 指出了新mysql_reset_connection功能(在 MySQL 5.7.3 中引入)。

参考:22.8.7.60 mysql_reset_connection() http://dev.mysql.com/doc/refman/5.7/en/mysql-reset-connection.html

看起来这个新函数实现了与我们通过断开和重新连接到 MySQL 获得的结果几乎相同的结果,但开销更少。

(现在我想知道 MariaDB 是否引入了类似的功能。)

于 2015-06-23T21:05:31.820 回答