Hallo,
ich habe einen Fall den ich nicht ganz verstehe und hoffe es gibt da eine Lösung zu.
In einer where-Bedingung möchte ich anhand eines Booleans entscheiden welche Bedingung genutzt werden soll.
Code:
-- 314 indizierte reads auf die Tabelle
T.ID = 1
-- 290 indizierte reads auf die Tabelle
T.ID= 20
-- 604 indizierte reads auf die Tabelle
( ( TRUE and
( T.ID = 1)) or
( not TRUE and
( T.ID= 20)))
Warum macht Firebird bei der verschachtelten Bedingung 604 reads und nicht 314?
Kann ich das evtl. mit einem vorgegebenen PLAN beeinflussen?
Hab ich probiert aber nicht hinbekommen mit dem PLAN bisher.