我试图使用临时表作为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语句.
解决这个问题的一种方法是简单地创建一个“真实”表,而不是临时表。
临时表的优点:
如果#1 对您来说至关重要,那么您可能需要坚持使用临时表。否则,如果该程序一次仅运行一个实例,或者如果您动态创建表名称以使其唯一,我建议您为此表选择一个适当的唯一名称并将其创建为“真实”表,然后完成后将其扔掉。
| 归档时间: |
|
| 查看次数: |
14769 次 |
| 最近记录: |