Бих предложил да напишете кода като:
SELECT SUM(dd.amt)
FROM db JOIN
dd
ON db.id = dd.dsba_id
WHERE dd.nd_id = xxxxxxx AND
dd.a_id = 'xxxxx-xx' AND
(db.v_id = xxxxxxxxx OR db.code = 'COMPLETE') AND
db.datet >= trunc(sysdate, 'YEAR');
За тази заявка бих препоръчал индекси на:
db(nd_id, a_id, id, datet, code)
dd(dsba_id, datet, v_id)
Промените в горната заявка:
- Никога използвайте запетаи в
FROM
клауза. Винаги използвайте правилно, изрично, стандартно , четимоJOIN
синтаксис. (Това обаче не засяга производителността.) decode()
е доста трудно за следване. Обикновено булевоor
е еквивалентен.BETWEEN
е ненужен, ако приемем, чеdatet
не е в бъдещето.SUM(NVL())
не е необходимо, защотоNULL
стойностите се игнорират. Ако сте загрижени заNULL
резултат, бих предложилCOALESCE(SUM(dd.amt), 0)