sql >> Base de Datos >  >> RDS >> Mysql

Subconsulta correlacionada de MySQL en la sintaxis JOIN

La respuesta a su pregunta es no, no es posible hacer referencia a nombres de correlación como lo está haciendo. La consulta interna produce la tabla derivada antes de que la consulta externa comience a evaluar las uniones. Así que los nombres de correlación como t , tp y u no están disponibles para la consulta interna.

Para resolver esto, recomendaría usar el mismo valor entero constante en la consulta interna y luego unir la tabla derivada en la consulta externa usando una condición real en lugar de 1=1 .

SELECT t.ticketid, u.userid, t.fullname, u.loginapi_userid, t.email,
  tp.subject, tp.contents, a.PhoneNumber, a.Location, a.Extension,
  a.BusinessUnit, a.Department
FROM swtickets t
 INNER JOIN swticketposts tp ON (t.ticketid = tp.ticketid)
 INNER JOIN swusers u ON (t.userid = u.userid)
 LEFT OUTER JOIN (
  SELECT cfv.typeid,
    MIN(CASE cfv.customfieldid WHEN 1 THEN cfv.fieldvalue END) AS 'PhoneNumber',
    MIN(CASE cfv.customfieldid WHEN 3 THEN cfv.fieldvalue END) AS 'Location',
    MIN(CASE cfv.customfieldid WHEN 5 THEN cfv.fieldvalue END) AS 'Extension',
    MIN(CASE cfv.customfieldid WHEN 8 THEN cfv.fieldvalue END) AS 'BusinessUnit',
    MIN(CASE cfv.customfieldid WHEN 9 THEN cfv.fieldvalue END) AS 'Department'
  FROM swcustomfieldvalues cfv
  WHERE cfv.typeid = 2458
  GROUP BY cfv.typeid
  ) AS a ON (a.typeid = t.ticketid)
WHERE t.ticketid = 2458;