2

我正在尝试引用子查询以在 case 语句中使用该值。但是,在 SELECT 语句中我不能引用,next_creation因为它只是抱怨该列不存在。我曾考虑将整个查询包装在 CASE 语句中,但 CASE 语句需要我多次运行查询,这似乎很愚蠢。

我也尝试过CROSS JOIN使用子查询,但它抱怨无法在子查询中引用 tg。内核错误:错误:对表“tg”的 FROM 子句条目的引用无效提示:表“tg”有一个条目,但不能从查询的这一部分引用。

我也尝试过使用 aWITH但它基本上与 CROSS JOIN 具有相同的结果。所以我什至尝试附加两个WITH子句,第一个查询在主OUTER查询中是相同的,所以第二个可以使用这些值....我遇到了一些错误。

有什么方法可以引用子查询,例如将其粘贴在要使用的变量中,同时仍允许子查询利用tg外部查询?

SELECT *, (
    SELECT
        tg2.created
    FROM tocom t
    LEFT JOIN tocom_g_assoc ON tocom_g_assoc.table_id = t.id AND tocom_g_assoc.tocom_g_id != tg.id
    LEFT JOIN tocom_g tg2 ON tg2.id = tocom_g_assoc.tocom_g_id
    WHERE t.id IN ( SELECT t_id FROM tocom_g_assoc WHERE tocom_g_assoc.tocom_g_id = tg.id )
        AND tg2.createdt > tg.created
        AND tg2.created IS NOT NULL
    ORDER BY tg2.created ASC
    LIMIT 1
) next_creation

/*
Here I want to do as CASE statement, but for argument sake,
a simple next_creation - tg.dissolved_at would do
*/

FROM wp p
LEFT JOIN tocom_g tg ON tg.id = p.tocom_g_id
WHERE tg.dissolved_at IS NOT NULL
4

1 回答 1

1

我意识到了这个问题。

所以我把它作为一个选择,返回子查询。然后我将整个事情包装在另一个选择中,并在 from 语句中进行查询。然后我可以对返回的值做任何我想做的事情。

于 2013-11-09T02:53:07.453 回答