Многократное двойное соединение с одним столом - PullRequest
0 голосов
/ 04 марта 2019

Пример 1 (работает нормально, выбирает назначенный агент ):

select cr.callid, cr.callstart, cr.callend, cr.waittime, cr.origin,
cr.origdestination, cr.waitresolution, cr.contacttype, cr.termtype,
u.userlastname as assignedagentname,
"" as answeringagentname from callrecord cr
left join (agentrecord ar left join users u on ar.agentkey=u.userkey)
on (cr.callid=ar.callid and cr.assignedagent=ar.sequencenumber);

Пример 2 (работает нормально, выбирает автоответчик ):

select cr.callid, cr.callstart, cr.callend, cr.waittime, cr.origin,
cr.origdestination, cr.waitresolution, cr.contacttype, cr.termtype,
"" as assignedagentname,
u.userlastname as answeringagentname from callrecord cr
left join (agentrecord ar left join users u on ar.agentkey=u.userkey)
on (cr.callid=ar.callid and cr.answeringagent=ar.sequencenumber);

Пример 3 (выдает ошибку, выбирает оба):

select cr.callid, cr.callstart, cr.callend, cr.waittime, cr.origin,
cr.origdestination, cr.waitresolution, cr.contacttype, cr.termtype,
u1.userlastname as assignedagentname,
u2.userlastname as answeringagentname from callrecord cr
left join (agentrecord ar left join users u1 on ar.agentkey=u1.userkey)
on (cr.callid=ar.callid and cr.assignedagent=ar.sequencenumber)
left join (agentrecord ar left join users u2 on ar.agentkey=u2.userkey)
on (cr.callid=ar.callid and cr.answeringagent=ar.sequencenumber);

Примеры 1 и 2 работают нормально и возвращают истинные результаты.В примере 3 я следовал советам по псевдонимам для нескольких объединений, найденным на этом форуме, но безуспешно.Я работаю с Informix DB через драйвер ODBC.

1 Ответ

0 голосов
/ 04 марта 2019

Попробуйте удалить скобки и убедитесь, что все псевдонимы уникальны:

select cr.callid, cr.callstart, cr.callend, cr.waittime, cr.origin,
       cr.origdestination, cr.waitresolution, cr.contacttype, cr.termtype,
       u1.userlastname as assignedagentname,
       u2.userlastname as answeringagentname
from callrecord cr left join
     agentrecord ar1
     on cr.callid = ar1.callid and
        cr.assignedagent = ar1.sequencenumber left join
     users u1
     on ar.agentkey = u1.userkey left join
     agentrecord ar2 
     on cr.callid = ar2.callid and 
        cr.answeringagent = ar2.sequencenumber left join
     users u2 on ar2.agentkey = u2.userkey
...