0

我正在尝试为 Interbase 编写 SQL 语句。

这个 SQL 有什么问题?

md_master (trm) = 主表 cd_Med (cdt) = 详细表

SELECT trm.seq_no, trm.recipient_id, trm.payee_fullname, trm.payee_address1, trm.payee_address2, trm.payee_address3, trm.payee_address_city, trm.payee_address_state, trm.recip_zip, trm.recip_zip_4, trm.recip_zip_4_2, trm.check_no, trm.check_date, trm.check_amount,
cdt.com_ss_source_sys, cdt.cd_pay_date, cdt.com_set_amount,
bnk.name, bnk.address, bnk.transit_routing,
act.acct_no
FROM md_master trm, cd_med cdt, accounts act, banks bnk
join cd_med on cdt.master_id = trm.id
join accounts on act.acct_id = trm.account_tag
join banks on bnk.bank_id = act.bank_id
ORDER BY cdt.master_id

我没有收到错误,计算机只是不停地运转并挂起。

4

3 回答 3

7

我不具体了解 Interbase,但 FROM 子句似乎有点奇怪(也许只是一些我不熟悉的语法)。这有帮助吗?

...
FROM md_master trm
join cd_med cdt on cdt.master_id = trm.id
join accounts act on act.acct_id = trm.account_tag
join banks bnk on bnk.bank_id = act.bank_id

顺便说一句,您没有 WHERE 子句,因此如果这些表中的任何一个很大,我不会对它需要很长时间才能运行感到过分惊讶。

于 2011-10-04T13:25:44.460 回答
1

你被一种叫做implicit join syntax

SELECT * FROM table_with_a_1000rows, othertable_with_a_1000rows

将对两个表进行交叉连接,在输出中选择 100 万行。

你正在做:

FROM md_master trm, cd_med cdt, accounts act, banks bnk

对 4 个表进行交叉连接(之后结合普通连接),可以轻松生成数十亿行。
难怪interbase挂起;它一直工作到时间结束,以生成更多的行,然后宇宙中的原子。

解决方案
永远不要,在 FROM 子句之后使用,这是一个隐式连接,它是邪恶的。
仅使用显式连接,如下所示:

SELECT 
  trm.seq_no, trm.recipient_id, trm.payee_fullname, trm.payee_address1
  , trm.payee_address2, trm.payee_address3, trm.payee_address_city
  , trm.payee_address_state, trm.recip_zip, trm.recip_zip_4, trm.recip_zip_4_2
  , trm.check_no, trm.check_date, trm.check_amount
  , cdt.com_ss_source_sys, cdt.cd_pay_date, cdt.com_set_amount
  , bnk.name, bnk.address, bnk.transit_routing
  , act.acct_no
FROM md_master trm
join cd_med on cdt.master_id = trm.id
join accounts on act.acct_id = trm.account_tag
join banks on bnk.bank_id = act.bank_id
ORDER BY cdt.master_id
于 2011-10-04T19:36:59.567 回答
0

错误在于 from 子句。您在 where 子句中使用一半带有逗号分隔的表而没有关系,而一半带有连接。

只需使用连接,一切都应该正常

于 2011-10-04T13:32:08.963 回答