English

Balsa: Learning a Query Optimizer Without Expert Demonstrations

Databases 2022-05-05 v2 Machine Learning

Abstract

Query optimizers are a performance-critical component in every database system. Due to their complexity, optimizers take experts months to write and years to refine. In this work, we demonstrate for the first time that learning to optimize queries without learning from an expert optimizer is both possible and efficient. We present Balsa, a query optimizer built by deep reinforcement learning. Balsa first learns basic knowledge from a simple, environment-agnostic simulator, followed by safe learning in real execution. On the Join Order Benchmark, Balsa matches the performance of two expert query optimizers, both open-source and commercial, with two hours of learning, and outperforms them by up to 2.8×\times in workload runtime after a few more hours. Balsa thus opens the possibility of automatically learning to optimize in future compute environments where expert-designed optimizers do not exist.

Keywords

Cite

@article{arxiv.2201.01441,
  title  = {Balsa: Learning a Query Optimizer Without Expert Demonstrations},
  author = {Zongheng Yang and Wei-Lin Chiang and Sifei Luan and Gautam Mittal and Michael Luo and Ion Stoica},
  journal= {arXiv preprint arXiv:2201.01441},
  year   = {2022}
}

Comments

SIGMOD 2022; code released at: https://github.com/balsa-project/balsa/