在多个表错误上左JOIN!(表或视图不存在)



我有以下SQL语法:

  SELECT firmenstamm.firmen_id,   
     firmenstamm.firmenname_1,   
     kreditorenstamm.kreditorenname_1,   
     debitor.debitoren_id,   
     debitor.deb_id_vom_kreditor,   
     debitorenstamm.debitorenname_1,   
     zahlung.zahlung_nr,   
     zahlung.zahlung_betrag,   
     zahlung.zahlung_betrag_offen,   
     zahlung.zahlung_datum,   
     kreditorenstamm.kreditoren_id,   
     bankbewegung.name_ag,   
     bankbewegung.verwendungzweck  
FROM debitor,   
     debitorenstamm,   
     firmenstamm,   
     kreditorenstamm,   
     zahlung 
     LEFT JOIN z_bankbewegung ON zahlung.zahlungs_id =   z_bankbewegung.zahlungs_id,
     LEFT JOIN bankbewegung ON z_bankbewegung.babe_id = bankbewegung.babe_id
 WHERE ( firmenstamm.firmen_id = kreditorenstamm.firmen_id ) and  
         ( kreditorenstamm.kreditoren_id = debitor.kreditoren_id ) and  
         ( debitor.debitoren_id = debitorenstamm.debitoren_id ) and  
         ( debitor.kreditoren_id = zahlung.kreditoren_id ) and  
         ( debitor.deb_id_vom_kreditor = zahlung.deb_id_vom_kreditor ) and  
         ( ( zahlung.zahlung_betrag_offen > 0 ) )   

我的问题现在是以下内容:如您所见,我在同一张桌子上进行了多个左键。我总是会收到错误消息"表或视图不存在"(ORA-00942(。

zahlung 
LEFT JOIN z_bankbewegung ON zahlung.zahlungs_id =   z_bankbewegung.zahlungs_id,
LEFT JOIN bankbewegung ON z_bankbewegung.babe_id = bankbewegung.babe_id

我看不到我的错误。有人有任何想法吗?

您正在混合古老的,古老的和脆弱的隐式连接(列出所有在从子句中被逗号隔开的桌子,然后将联接条件放入其中(和"现代" 1(明确加入操作员。不要那样做。使用明确连接到所有内容:

SELECT ...
FROM debitor
  JOIN debitorenstamm ON debitor.debitoren_id = debitorenstamm.debitoren_id
  JOIN kreditorenstamm ON kreditorenstamm.kreditoren_id = debitor.kreditoren_id
  JOIN firmenstamm ON firmenstamm.firmen_id = kreditorenstamm.firmen_id
  JOIN zahlung
    ON debitor.kreditoren_id = zahlung.kreditoren_id
   AND debitor.deb_id_vom_kreditor = zahlung.deb_id_vom_kreditor
  LEFT JOIN z_bankbewegung ON zahlung.zahlungs_id = z_bankbewegung.zahlungs_id
  LEFT JOIN bankbewegung ON z_bankbewegung.babe_id = bankbewegung.babe_id
WHERE zahlung.zahlung_betrag_offen > 0

1("现代"是相对的:1992年以上的SQL标准中引入了显式连接。因此,从"全新"的意义上讲,这几乎不是"现代"。

最新更新