在MySql中多次访问临时表

Mar*_*ark 5 mysql temp-tables

我试图使用临时表作为SELECT语句的中间结果持有者.问题是虽然我无法在其他查询语句中多次访问临时表,我希望这可能会使临时表无用.

是否有替代MySql中的临时表,允许我提取我的SQL语句.

我不能使用存储过程(无法从公司使用的Web框架版本访问它们),我不想使用游标.

编辑:

好吧,我的代码看起来有点像这样:

临时表创建:

CREATE TEMPORARY TABLE dates_with_entries (
  seq  INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
  datum VARCHAR(32)
);

INSERT INTO dates_with_entries (datum) SELECT datum AS Datum from project_times
    WHERE user_id = 20 GROUP BY datum ORDER BY datum desc LIMIT 13;
Run Code Online (Sandbox Code Playgroud)

那么我使用临时表的代码看起来有点像这样(我把它简化为我遇到的问题..)

SELECT 
...
FROM (SELECT entrie_date AS datum FROM dates_with_entries ) AS sub_result
INNER JOIN project_times
    ON sub_result.datum = project_times.datum AND project_times.user_id = 20
LEFT JOIN works AS w ON project_times.work_id = w.id
LEFT JOIN sub_projects AS sp ON sp.id = w.sub_project_id
LEFT JOIN projects AS p ON p.id = sp.project_id
GROUP BY datum
UNION(
    SELECT
      ..
  FROM (SELECT entrie_date AS datum FROM dates_with_entries ) AS sub_result
  INNER JOIN project_times AS pt ON pt.datum = sub_result.datum
  INNER JOIN works AS w on w.id = pt.work_id
  INNER JOIN sub_projects AS sp on w.sub_project_id = sp.id
  INNER JOIN projects AS p ON sp.project_id = p.id
  WHERE pt.user_id = 20
);
Run Code Online (Sandbox Code Playgroud)

这些数字稍后将被ruby替换,这仅用于测试SQL语句.

Ike*_*ker 5

解决这个问题的一种方法是简单地创建一个“真实”表,而不是临时表。

临时表的优点:

  1. 命名空间。您可以在单独的会话中创建多个具有相同名称的临时表。
  2. 自动清理。完成后,您不需要显式删除该表。当您结束会话时它就会消失

如果#1 对您来说至关重要,那么您可能需要坚持使用临时表。否则,如果该程序一次仅运行一个实例,或者如果您动态创建表名称以使其唯一,我建议您为此表选择一个适当的唯一名称并将其创建为“真实”表,然后完成后将其扔掉。