Compiling PL/SQL Away

Christian Duta,Denis Hirn,Torsten Grust
DOI: https://doi.org/10.48550/arXiv.1909.03291
2019-09-07
Abstract:"PL/SQL functions are slow," is common developer wisdom that derives from the tension between set-oriented SQL evaluation and statement-by-statement PL/SQL interpretation. We pursue the radical approach of compiling PL/SQL away, turning interpreted functions into regular subqueries that can then be efficiently evaluated together with their embracing SQL query, avoiding any PL/SQL to SQL context switches. Input PL/SQL functions may exhibit arbitrary control flow. Iteration, in particular, is compiled into SQL-level recursion. RDBMSs across the board reward this compilation effort with significant run time savings that render established developer lore questionable.
Databases,Programming Languages
What problem does this paper attempt to address?