SQLite:尝试从两个 select 语句的连接创建新表时找不到表别名



我希望这个标题有意义,我对编写查询相当陌生,并且对术语等内容感到不安。

我需要一些帮助来理解为什么在以下查询中找不到我的表别名。当我在没有 ON 子句的情况下运行它时,它会执行(在 Firefox 上的 SQLite 管理器上),但使用该子句,我收到错误"没有这样的列t2.story_id"

注意 - 我正在使用我创建的一些虚拟查询来简化问题。我的最终查询将完全相同,因此,如果您看到任何错误或我可以改进的内容,请分享。如果有人想知道为什么这两个语句从同一个表中提取,那是因为我需要连接两个从同一个表中提取但执行无法同时完成的非常具体的事情的语句。至少我被告知这是这样做的方法哈哈。

   SELECT * FROM
    (
           SELECT * FROM
             (
                 SELECT story_id, role_type, user_id 
                 FROM cur_cycle_role_activity
             ) t1 /* end of the first inner select statement t1 */
                LEFT JOIN /* Begin Join Statement */
                (
                  SELECT * FROM
                  (
                       SELECT story_id, workstream_num FROM cur_cycle_role_activity
                  ) t2 /* end of the second inner select statement t2 */
                ) /* End Join */
                ON t1.story_id = t2.story_id /* On clause for Join above */
    ) /* This is the end of the topmost select statement */

错误信息:

    [ no such column: t2.story_id ]

查询包装在 SELECT * FROM (...) 中会导致问题,因为您无法在子查询中引用别名。

SELECT t1.story_id, t1.role_type, t1.user_id, t2.workstream_num
FROM (
    SELECT story_id, role_type, user_id 
    FROM cur_cycle_role_activity) AS t1
LEFT JOIN (
    SELECT story_id, workstream_num
    FROM cur_cycle_role_activity) AS t2
ON t1.story_id = t2.story_id

相关内容

  • 没有找到相关文章