Sql 带有左连接的子句导致找不到列
Sql clause with left join causing column not found
我正在尝试使用 left join 在一堆表(MySQL 数据库)中创建一个 select,这导致了我找不到列:
SQLSTATE[42S22]:找不到列:1054 'on clause'
中的未知列 'per_idn_validacao'
这是我的 sql 声明:
SELECT pes_idn_pergunta_especificidade,
pes_idn_tipo_especificidade,
pes_idn_pergunta,
pes_des_ordem,
pes_flg_obrigatoriedade ,
tes_idn_tipo_especificidade,
tes_des_descricao,
pro_idn_programa,
pro_des_descricao,
per_idn_pergunta,
per_idn_resposta,
per_idn_validacao,
per_idn_tipo,
per_des_descricao,
per_flg_autocompletar,
per_des_ordem,
per_des_strategy,
per_des_hint,
tpp_idn_tipo,
tpp_des_descricao,
tre_idn_tipo,
tre_des_descricao
FROM
slt_pergunta_especificidade,
slt_tipo_especificidade,
slt_programa, slt_pergunta,
slt_tipo_resposta, slt_tipo_pergunta
LEFT JOIN slt_tipo_validacao ON per_idn_validacao = tvl_idn_validacao
WHERE pro_idn_programa = tes_idn_programa
AND tpp_idn_tipo = per_idn_tipo
AND per_idn_pergunta = pes_idn_pergunta AND tre_idn_tipo = per_idn_resposta AND tes_idn_tipo_especificidade = pes_idn_tipo_especificidade
AND pes_idn_tipo_especificidade = :id
ORDER BY pes_des_ordem
谁能帮我解决这个问题?
这是仅使用 JOIN
语法重写的查询:
(注意:需要对 ON
谓词中的列进行排列,以便在它所在的 table 之前不会出现任何列。
SELECT pes_idn_pergunta_especificidade,
pes_idn_tipo_especificidade,
pes_idn_pergunta,
pes_des_ordem,
pes_flg_obrigatoriedade ,
tes_idn_tipo_especificidade,
tes_des_descricao,
pro_idn_programa,
pro_des_descricao,
per_idn_pergunta,
per_idn_resposta,
per_idn_validacao,
per_idn_tipo,
per_des_descricao,
per_flg_autocompletar,
per_des_ordem,
per_des_strategy,
per_des_hint,
tpp_idn_tipo,
tpp_des_descricao,
tre_idn_tipo,
tre_des_descricao
FROM slt_pergunta_especificidade
JOIN slt_tipo_especificidade
ON pro_idn_programa = tes_idn_programa
JOIN slt_programa
ON tpp_idn_tipo = per_idn_tipo
JOIN slt_pergunta
ON per_idn_pergunta = pes_idn_pergunta
JOIN slt_tipo_resposta
ON tre_idn_tipo = per_idn_resposta
JOIN slt_tipo_pergunta
ON tes_idn_tipo_especificidade = pes_idn_tipo_especificidade
LEFT JOIN slt_tipo_validacao
ON per_idn_validacao = tvl_idn_validacao
WHERE pes_idn_tipo_especificidade = :id
ORDER BY pes_des_ordem
我正在尝试使用 left join 在一堆表(MySQL 数据库)中创建一个 select,这导致了我找不到列:
SQLSTATE[42S22]:找不到列:1054 'on clause'
中的未知列 'per_idn_validacao'这是我的 sql 声明:
SELECT pes_idn_pergunta_especificidade,
pes_idn_tipo_especificidade,
pes_idn_pergunta,
pes_des_ordem,
pes_flg_obrigatoriedade ,
tes_idn_tipo_especificidade,
tes_des_descricao,
pro_idn_programa,
pro_des_descricao,
per_idn_pergunta,
per_idn_resposta,
per_idn_validacao,
per_idn_tipo,
per_des_descricao,
per_flg_autocompletar,
per_des_ordem,
per_des_strategy,
per_des_hint,
tpp_idn_tipo,
tpp_des_descricao,
tre_idn_tipo,
tre_des_descricao
FROM
slt_pergunta_especificidade,
slt_tipo_especificidade,
slt_programa, slt_pergunta,
slt_tipo_resposta, slt_tipo_pergunta
LEFT JOIN slt_tipo_validacao ON per_idn_validacao = tvl_idn_validacao
WHERE pro_idn_programa = tes_idn_programa
AND tpp_idn_tipo = per_idn_tipo
AND per_idn_pergunta = pes_idn_pergunta AND tre_idn_tipo = per_idn_resposta AND tes_idn_tipo_especificidade = pes_idn_tipo_especificidade
AND pes_idn_tipo_especificidade = :id
ORDER BY pes_des_ordem
谁能帮我解决这个问题?
这是仅使用 JOIN
语法重写的查询:
(注意:需要对 ON
谓词中的列进行排列,以便在它所在的 table 之前不会出现任何列。
SELECT pes_idn_pergunta_especificidade,
pes_idn_tipo_especificidade,
pes_idn_pergunta,
pes_des_ordem,
pes_flg_obrigatoriedade ,
tes_idn_tipo_especificidade,
tes_des_descricao,
pro_idn_programa,
pro_des_descricao,
per_idn_pergunta,
per_idn_resposta,
per_idn_validacao,
per_idn_tipo,
per_des_descricao,
per_flg_autocompletar,
per_des_ordem,
per_des_strategy,
per_des_hint,
tpp_idn_tipo,
tpp_des_descricao,
tre_idn_tipo,
tre_des_descricao
FROM slt_pergunta_especificidade
JOIN slt_tipo_especificidade
ON pro_idn_programa = tes_idn_programa
JOIN slt_programa
ON tpp_idn_tipo = per_idn_tipo
JOIN slt_pergunta
ON per_idn_pergunta = pes_idn_pergunta
JOIN slt_tipo_resposta
ON tre_idn_tipo = per_idn_resposta
JOIN slt_tipo_pergunta
ON tes_idn_tipo_especificidade = pes_idn_tipo_especificidade
LEFT JOIN slt_tipo_validacao
ON per_idn_validacao = tvl_idn_validacao
WHERE pes_idn_tipo_especificidade = :id
ORDER BY pes_des_ordem