Issue No. 02 - March/April (2000 vol. 12)
DOI Bookmark: http://doi.ieeecomputersociety.org/10.1109/69.842265
<p><b>Abstract</b>—It is striking that the optimization of disjunctive queries—i.e., those which contain at least one <b>or</b>-connective in the query predicate—has been vastly neglected in the literature, as well as in commercial systems. In this paper, we propose a novel technique, called <it>bypass processing</it>, for evaluating such disjunctive queries. The bypass processing technique is based on new selection and join operators that produce two output streams: the <it>true</it>-stream with tuples satisfying the selection (join) predicate and the <it>false</it>-stream with tuples not satisfying the corresponding predicate. Splitting the tuple streams in this way enables us to “bypass” costly predicates whenever the “fate” of the corresponding tuple (stream) can be determined without evaluating this predicate. In the paper, we show how to systematically generate bypass evaluation plans utilizing a bottom-up building block approach. We show that our evaluation technique allows to incorporate the standard SQL semantics of null values. For this, we devise two different approaches: One is based on explicitly incorporating three-valued logic into the evaluation plans; the other one relies on two-valued logic by “moving” all negations to atomic conditions of the selection predicate. We describe how to extend an iterator-based query engine to support bypass evaluation with little extra overhead. This query engine was used to quantitatively evaluate the bypass evaluation plans against the traditional evaluation techniques utilizing a CNF- or DNF-based query predicate.</p>
Query optimization, query processing, disjunctive queries, query evaluation plans, expensive query predicates, bypass processing.
G. Moerkotte, A. Kemper, M. Steinbrunn, J. Claussen and K. Peithner, "Optimization and Evaluation of Disjunctive Queries," in IEEE Transactions on Knowledge & Data Engineering, vol. 12, no. , pp. 238-260, 2000.